中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在java 項目中使用歸并排序算法

發布時間:2020-11-26 16:27:06 來源:億速云 閱讀:141 作者:Leah 欄目:編程語言

怎么在java 項目中使用歸并排序算法?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

歸并排序

       歸并排序,指的是將兩個已經排序的序列合并成一個序列的操作。 

歸并操作的過程如下:

  •  申請空間,使其大小為兩個已經排序序列之和,該空間用來存放合并后的序列

  •  設定兩個指針,最初位置分別為兩個已經排序序列的起始位置

  •  比較兩個指針所指向的元素,選擇相對小的元素放入到合并空間,并移動指針到下一位置

  •  重復步驟3直到某一指針到達序列尾

  •  將另一序列剩下的所有元素直接復制到合并序列尾

Java代碼 

/** 
 * 歸并排序 
 * 
 * @param ts 
 */ 
@SuppressWarnings("unchecked") 
public static <T extends Comparable<? super T>> void mergeSort(T[] ts) { 
 
  // 輔助空間 
  T[] tempArray = (T[]) new Comparable[ts.length]; 
 
  mergeSort(ts, tempArray, 0, ts.length - 1); 
} 
 
/** 
 * 遞歸 
 */ 
private static <T extends Comparable<? super T>> void mergeSort(T[] ts, T[] tempArray, int left, int right) { 
 
  if (left < right) { 
 
    int center = (left + right) / 2; 
 
    mergeSort(ts, tempArray, left, center); 
 
    mergeSort(ts, tempArray, center + 1, right); 
 
    // 左右合并 
    merge(ts, tempArray, left, center + 1, right); 
 
  } 
 
} 
 
/** 
 * 合并 
 */ 
private static <T extends Comparable<? super T>> void merge(T[] ts, T[] tempArray, int leftPos, int rightPos, int rightEnd) { 
  int leftEnd = rightPos - 1; 
  int temPos = leftPos; 
  int numElements = rightEnd - leftPos + 1; 
 
  while (leftPos <= leftEnd && rightPos <= rightEnd) 
    //比較放到輔助空間 
    if (ts[leftPos].compareTo(ts[rightPos]) <= 0) 
      tempArray[temPos++] = ts[leftPos++]; 
    else 
      tempArray[temPos++] = ts[rightPos++]; 
 
  while (leftPos <= leftEnd) 
    tempArray[temPos++] = ts[leftPos++]; 
 
  while (rightPos <= rightEnd) 
    tempArray[temPos++] = ts[rightPos++]; 
 
  //考回原數組,此處最好用System.arraycopy優化 
  for (int i = 0; i < numElements; i++, rightEnd--) 
    ts[rightEnd] = tempArray[rightEnd]; 
}

 復雜度:O(n log n)

       比較操作的次數介于(n log n)/2和n log n - n + 1。 賦值操作的次數是(2nlogn)。

       歸并算法的空間復雜度為:Θ(n) 

 穩定性:穩定 

擴展:

       在java中,當執行一次泛型排序時,進行一次元比較可能是昂貴的,但是移動元素則是省時間的。歸并排序使用所有的流行的排序算法中最少的比較次數,因此是使用java的通用排序算中的上好的選擇。

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

长海县| 大埔县| 丹东市| 庆元县| 页游| 舞阳县| 天台县| 望江县| 柏乡县| 阳谷县| 综艺| 永春县| 定日县| 桐梓县| 出国| 辛集市| 徐汇区| 翁源县| 永靖县| 瑞安市| 南川市| 易门县| 武宣县| 云阳县| 德安县| 桓台县| 沈阳市| 大同市| 建水县| 乐平市| 乡宁县| 盐边县| 霍林郭勒市| 崇信县| 雷州市| 通道| 遂平县| 秦安县| 桓台县| 贵定县| 三都|