一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

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

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實現歸并排序算法

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 精品国产福利片在线观看 | 满城尽带黄金甲大胸片 | 男人操女生 | 青青青在线视频播放 | 国产精品亚洲片在线va | 亚洲欧美精品一区二区 | 国产美女下面流出白浆视频 | 99热精品在线观看 | 国内精品91最新在线观看 | 免费看片aⅴ免费大片 | 精品国产91久久久久 | 国产一级片免费视频 | 给我一个黄色网址 | 青草国内精品视频在线观看 | 美女被视频网站看免费入口 | 亚洲人成网站在线观看90影院 | 国产欧美视频一区二区三区 | 欧美日韩国产一区二区三区不卡 | 日本高清视频网址 | free哆拍拍免费永久视频 | 娇妻终于接受了3p的调教 | 欧美丰满大乳大屁在线观看股 | 国产成人精品免费2021 | 草莓视频在线观看免费 | 男人j进女屁股视频在线观看 | 午夜影院在线免费观看 | 久久久精品成人免费看 | 紧身牛仔裤美女被啪啪久久网 | 午夜影院费试看黄 | 亚州免费一级毛片 | 1769在线观看 | jiuse在线 | 精品在线播放视频 | 香蕉成人999视频 | 久久黄色录像 | 国产精品女主播大秀在线 | 非洲黑人bbwbbwbbw | 包臀裙女教师波多野结衣 | 香蕉久久夜色精品国产尤物 | 日本红怡院亚洲红怡院最新 | v视界影院成片 |