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

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

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 91久久青青青国产免费 | 欧美性xxxxx| 欧美人禽杂交在线视频 | 日本国产一区二区三区 | 我将她侵犯1~6樱花动漫在线看 | 黄情视频| 丫鬟粗大狠狠贯穿h | 91精品天美精东蜜桃传媒免费 | 国产欧美综合精品一区二区 | 国产高清ujzzujzz | 91tv破解版不限次数 | 日韩视频在线观看中字 | 国产精品视频1区 | 女同全黄h全肉动漫 | 欧美福利二区 | 国产成人啪精品视频站午夜 | 国产精品亚洲午夜不卡 | 91极品国产| 精品91自产拍在线观看99re | 国产高清在线精品一区二区 | 蜜臀91 | 黑人破中国女人处 | 午夜精品久久久久久中宇 | 日韩欧美中文字幕一区 | 亚洲日韩精品欧美一区二区一 | 国产精品久久免费观看 | 美国一级大黄大色毛片 | 五月婷婷俺来也 | 久九九精品免费视频 | 69热精品视频在线看影院 | 国产一区二区在线观看美女 | 女人用粗大自熨喷水在线视频 | 草草影院永久在线观看 | 久久这里有精品 | 色网免费观看 | 国产精品亚洲专区在线播放 | 疯狂刺激的3p国产在线 | japonensis中国东北老人 | 99久久香蕉国产线看观香 | 日韩网站免费 | 风间由美理论片在线观看 |