91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

怎么在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

虎林市| 藁城市| 六盘水市| 延安市| 广河县| 六安市| 岳阳市| 郎溪县| 冷水江市| 大洼县| 洪雅县| 舒城县| 鄢陵县| 观塘区| 驻马店市| 邓州市| 马公市| 义乌市| 黄梅县| 龙州县| 江津市| 子洲县| 清镇市| 松潘县| 团风县| 南平市| 平山县| 陕西省| 赣州市| 台安县| 桃园市| 拉孜县| 砚山县| 潼南县| 开化县| 屯昌县| 贵溪市| 山阴县| 化州市| 嘉义市| 西乌珠穆沁旗|