java演算法專題-歸併排序

來源:互聯網
上載者:User

歸併的思想就是分治.

Java代碼
 
  1.   
  2. public class Test1 {   
  3.     public static void main(String[] args) {   
  4.         int[] arr1 = { 4,23,234,3,41,311,3,5 ,56,5,46};
      
  5.         int[] arr2 = { 4,23,234,3,41,311,3,5 ,56,5,46};
      
  6.         Test1 test1 = new Test1();   
  7.         test1.splitAndMerger(arr1, 0, arr1.length-1);   
  8.         test1.printArray(arr1);   
  9.         test1.printArray(arr2) ;   
  10.         Arrays.sort(arr2) ;   
  11.         test1.printArray(arr2) ;   
  12.     }   
  13.   
  14.     public void splitAndMerger(int[] ints, int begin, int end) {
      
  15.         int mid = (begin + end) / 2;   
  16.         if (end > begin) {   
  17.             splitAndMerger(ints, begin, mid);   
  18.             splitAndMerger(ints, mid + 1, end);   
  19.             merger(ints, begin, mid, end);   
  20.         }   
  21.     }   
  22.   
  23.     public void merger(int[] ints, int begin, int mid, int end) {
      
  24.         int temp1 = 0;   
  25.         int temp2 = 0;   
  26.         int[] arr1 = Arrays.copyOfRange(ints, begin, mid+1);   
  27.         int[] arr2 = Arrays.copyOfRange(ints, mid+1, end+1);
      
  28.   
  29.         for (int i = begin; i <= end; i++) {   
  30.             if (temp1 == arr1.length  && temp2 == arr2.length) {   
  31.                 break;   
  32.             }   
  33.             if (temp1 == arr1.length) {   
  34.                 ints[i] = arr2[temp2];   
  35.                 temp2++;   
  36.                 continue;   
  37.             }   
  38.             if (temp2 == arr2.length) {   
  39.                 ints[i] = arr1[temp1];   
  40.                 temp1++;   
  41.                 continue;   
  42.             }   
  43.             if (arr1[temp1] > arr2[temp2]) {   
  44.                 ints[i] = arr2[temp2];   
  45.                 temp2++;   
  46.             } else {   
  47.                 ints[i] = arr1[temp1];   
  48.                 temp1++;   
  49.             }   
  50.         }   
  51.     }   
  52.   
  53.     public void printArray(int[] array) {   
  54.         this.printArray(array, 0, array.length-1);   
  55.     }   
  56.   
  57.     public void printArray(int[] array, int begin, int end) {
      
  58.         for (int i = begin; i <= end; i++) {   
  59.             System.out.print(array[i] + "   ");   
  60.         }   
  61.         System.out.println();   
  62.     }   

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.