java算法专题-归并排序

转载 2012年03月26日 09:34:55

归并的思想就是分治.

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.     }   

 

图解归并排序算法(java版)

归并排序:采用分治法的思想(递归),将整个数组序列分成两个序列,再讲两个序列分成各自的子序列,采用递归的思想解决一个个的子问题。归并排序的时间复杂度:O(n*lgn) 归病排序的空间复杂度:O(n)...

递归归并排序算法

  • 2017年11月02日 22:33
  • 2KB
  • 下载

分治归并排序算法——Java实现

1、分治法 许多有用的算法在结构上是递归的:为了解决一个给定的问题,算法一次或多次递归地调用其自身以解决紧密相关的若干子问题。这些算法典型地遵循分治法的思想:将原问题分解为几个规模较小但类似于原问题的...

归并排序算法

  • 2013年10月27日 09:56
  • 5KB
  • 下载

归并排序算法代码实现

  • 2012年11月15日 19:20
  • 2KB
  • 下载

java实现归并排序算法

1.归并排序算法的思想 归并排序主要是使用了递归排序的算法。采用分治思想的策略。要将一个数组排序,先递归地将它分成两半分别排序,然后将结果归并起来。由于需要将两个数组归并到第三个新的数组中去。所以应...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:java算法专题-归并排序
举报原因:
原因补充:

(最多只允许输入30个字)