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

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

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - java 基本算法之歸并排序實例代碼

java 基本算法之歸并排序實例代碼

2020-09-23 14:04Java之家 Java教程

這篇文章主要介紹了java 基本算法之歸并排序實例代碼的相關資料,需要的朋友可以參考下

java 基本算法歸并排序實例代碼

原理:歸并(Merge)排序法是將兩個(或兩個以上)有序表合并成一個新的有序表,

     * 即把待排序序列分為若干個子序列,每個子序列是有序的。
     * 然后再把有序子序列合并為整體有序序列。

實例代碼:

?
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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
public class MergeSort {
 
  /**
   *
   *
   *
   * @param args
   */
  public static void main(String[] args) {
    int a[] = { 49, 38, 65, 97, 76, 13, 27, 49, 78, 34, 12, 64, 5, 4, 62,
        99, 98, 54, 56, 17, 18, 23, 34, 15, 35, 25, 53, 51 };
 
    sort(a, 0, a.length - 1);
    System.out.println(Arrays.toString(a));
 
  }
 
  public static void sort(int[] data, int left, int right) {
    if (left < right) {
      // 找出中間索引
      int center = (left + right) / 2;
      // 對左邊數組進行遞歸
      sort(data, left, center);
      // 對右邊數組進行遞歸
      sort(data, center + 1, right);
      // 合并
      merge(data, left, center, right);
    }
 
  }
 
  public static void merge(int[] data, int left, int center, int right) {
    int[] tmpArr = new int[data.length];
    int mid = center + 1;
    // third記錄中間數組的索引
    int third = left;
    int tmp = left;
    while (left <= center && mid <= right) {
      // 從兩個數組中取出最小的放入中間數組
      if (data[left] <= data[mid]) {
        tmpArr[third++] = data[left++];
      } else {
        tmpArr[third++] = data[mid++];
      }
 
    }
 
    // 剩余部分依次放入中間數組
    while (left <= center) {
      tmpArr[third++] = data[left++];
    }
    while (mid <= right) {
      tmpArr[third++] = data[mid++];
    }
 
    // 將中間數組中的內容復制回原數組
    while (tmp <= right) {
      data[tmp] = tmpArr[tmp++];
    }
    System.out.println(Arrays.toString(data));
  }
 
}

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

原文鏈接:https://my.oschina.net/songxinqiang/blog/710395

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日本中文字幕不卡在线一区二区 | 欧美久久综合网 | 久久久久久88色偷偷 | 国产香蕉一区二区在线观看 | 91精品国产免费久久国语蜜臀 | 精品一区二区国语对白 | 丰满大屁股美女一级毛片 | 暖暖视频日本 | 国产伦精一区二区三区视频 | 香蕉在线精品一区二区 | 盲井在线| 欧美一区二区三区gg高清影视 | aⅴ导航站 | 无套大战白嫩乌克兰美女 | 艹b视频在线观看 | 亚洲人成网站在线观看青青 | 亚洲免费闲人蜜桃 | 日韩黄色影视 | 免费在线观看网址大全 | 久久99re8热在线播放 | 操操久久 | 欧美色青 | 日韩成人精品在线 | 国产a在线 | 91国语自产拍在线观看 | 四虎影院永久网址 | 九九在线精品亚洲国产 | 韩国日本香港毛片免费 | 男男视频18免费网站 | 国产三级精品久久三级国专区 | 国产午夜免费视频 | 欧美一级视频在线高清观看 | 国产区最新 | 免费真实播放国产乱子伦 | 国产成人一区二区三区小说 | avidolz中文版| 午夜国产在线观看 | 国产日韩欧美在线一区二区三区 | 韩国三级年轻的小婊孑 | 91私密保健女子养生spa | 免费lulu网站 |