首页 > 代码库 > 归并排序
归并排序
一、归并排序
package algorithm.sort.compare.merge;
import java.util.Arrays;
public class MergeSort {
public static void main(String[] args) {
int[] arrayA = new int[] { 11, 213, 134, 65, 77, 78, 23, 43 };
mergeSort (arrayA, 0, arrayA.length - 1, new int[arrayA.length]);
System.out.println (Arrays.toString (arrayA));
}
private static void mergeSort ( int[] array, int start, int end, int[] tempArray ){
if (end <= start)
return;
int middle = ( start + end )/2;
mergeSort (array, start, middle, tempArray);
mergeSort (array, middle + 1, end, tempArray);
int k = 0, leftIndex = 0, rightIndex = end - start;
System.arraycopy (array, start, tempArray, 0, middle - start + 1);
for ( int i = 0; i < end - middle; i++ )
tempArray[end - start - i] = array[middle + i + 1];
while (k < end - start + 1){
if (tempArray[rightIndex] > tempArray[leftIndex]) // 从小到大
array[k + start] = tempArray[leftIndex++];
else
array[k + start] = tempArray[rightIndex--];
k++;
}
}
}
归并排序
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。