码迷,mamicode.com
首页 > 编程语言 > 详细

java实现归并排序算法

时间:2015-04-09 20:06:39      阅读:127      评论:0      收藏:0      [点我收藏+]

标签:public   java   元素   

第一, 分解: 把待排序的 n 个元素的序列分解成两个子序列, 每个子序列包括 n/2 个元素.

第二, 治理: 对每个子序列分别调用归并排序MergeSort, 进行递归操作

第三, 合并: 合并两个排好序的子序列,生成排序结果.

来自CODEGO.NET的代码:

 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实现归并排序算法

标签:public   java   元素   

原文地址:http://10092928.blog.51cto.com/10082928/1630642

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!