国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - java實現歸并排序算法

java實現歸并排序算法

2019-12-15 15:17hebedich JAVA教程

歸并排序:是建立在歸并操作上的一種有效的排序算法。該算法是采用分治法(Divide and Conquer)的一個非常典型的應用。 本文我們就來詳細的探討下。

歸并排序算法思想:
分而治之(divide - conquer);每個遞歸過程涉及三個步驟
第一, 分解: 把待排序的 n 個元素的序列分解成兩個子序列, 每個子序列包括 n/2 個元素.
第二, 治理: 對每個子序列分別調用歸并排序MergeSort, 進行遞歸操作
第三, 合并: 合并兩個排好序的子序列,生成排序結果.

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
public static void mergeSort(int[] a, int[] tmp, int left, int right) {
    if (left < right) {
      int mid = left + (right - left) / 2;
      mergeSort(a, tmp, left, mid);// 左排序
      mergeSort(a, tmp, mid + 1, right);// 右排序
      merge(a, tmp, left, mid + 1, right);// 左右合并
    }
  }
public static void merge(int[] a, int[] tmp, int left, int rightPos,
      int right) {
    int leftEnd = rightPos - 1;
    int tmpPos = left;
    int num = right - left + 1;
    while (left <= leftEnd && rightPos <= right) {
      if (a[left] < a[rightPos]) {
        tmp[tmpPos++] = a[left++];
      } else {
        tmp[tmpPos++] = a[rightPos++];
      }
    }
    while (left <= leftEnd) {
      tmp[tmpPos++] = a[left++];
    }
    while (rightPos <= right) {
      tmp[tmpPos++] = a[rightPos++];
    }
    for (int i = 0; i < num; i++, right--) {
      a[right] = tmp[right];
    }
  }

歸并算法示意圖:

java實現歸并排序算法

以上所述就是本文的全部內容了,希望大家能夠喜歡。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 精品一二三四区 | 亚洲精品久久久久久久久久吃药 | www.久久久 | 夜夜嗨av色一区二区不卡 | 成年人免费网站 | 1000部精品久久久久久久久 | 俺去俺来也在线www色官网 | 成人黄色片网站 | 日韩高清一区二区 | 久草免费在线视频 | 99热国产在线观看 | 日本中文字幕在线播放 | 午夜爱爱毛片xxxx视频免费看 | 欧美大片免费观看 | 欧美第一区| 中文字幕欧美激情 | 中文字幕在线观看精品视频 | 成人h漫在线观看 | 久久国产欧美日韩精品 | 国产视频久久 | 国产亚洲精品精品国产亚洲综合 | 无码一区二区三区视频 | 黄色毛片网站在线观看 | 欧美三区 | 日本久久免费 | 久久噜噜噜精品国产亚洲综合 | 国产日韩欧美在线 | 亚洲激情网站 | 伊人伊人| 国产精品久久久久久模特 | 久精品视频 | 在线视频 亚洲 | 欧美香蕉| 国产一区二 | 久久天天| 精品久久av | 亚洲色图50p | 国产成人在线一区二区 | 免费精品 | 精品一区二区三区视频 | 亚洲精品久久久 |