Java排序五:归并排序
来源:互联网 发布:淘宝自定义轮播代码 编辑:程序博客网 时间:2024/05/16 07:00
public class TestDemo {public static void main(String[] args) {int[] arr = new int[10];Random random = new Random();for (int i = 0; i < arr.length; i++) {arr[i] = random.nextInt(100);}display(arr);sort(arr, 0, arr.length - 1);display(arr);}public static void sort(int[] arr, int left, int right) {if (left >= right)return;int middle = (left + right) >> 0x1;sort(arr, left, middle);sort(arr, middle + 1, right);merge(arr, left, middle, right);}private static void merge(int[] arr, int left, int middle, int right) {int[] tmpArr = new int[arr.length];int tmpIndex, startIndex;tmpIndex = startIndex = left;int secLeft = middle + 1;while (left <= middle && secLeft <= right) {if (arr[left] <= arr[secLeft]) {tmpArr[tmpIndex++] = arr[left++];} else {tmpArr[tmpIndex++] = arr[secLeft++];}}while (left <= middle) {tmpArr[tmpIndex++] = arr[left++];}while (secLeft <= right) {tmpArr[tmpIndex++] = arr[secLeft++];}System.arraycopy(tmpArr, startIndex, arr, startIndex, right - startIndex + 1);}private static void swap(int[] arr, int i, int j) {if (i == j) {return;}arr[i] = arr[i] ^ arr[j];arr[j] = arr[i] ^ arr[j];arr[i] = arr[i] ^ arr[j];}private static void display(int[] arr) {for (int i = 0, len = arr.length; i < len; i++) {System.out.print(arr[i] + " ");}System.out.println();}}
0 0
- Java排序五:归并排序
- 排序五 归并排序
- 排序算法(五)--归并排序
- 排序算法(五) - 归并排序
- 【排序算法五】归并排序
- java排序--归并排序
- 排序-归并排序-Java
- Java排序算法总结(五):归并排序
- Java排序算法总结(五):归并排序
- 【Java】五种常见排序之----------------归并排序
- 排序算法(五):JAVA实现归并排序
- java五种内部排序(直接插入排序、希尔排序、快速排序、堆排序、归并排序)
- Java排序算法 归并排序
- Java 排序之 归并排序
- java排序算法---归并排序
- 归并排序(Java) @排序
- Java排序算法:归并排序
- JAVA排序算法---归并排序
- try catch 的 return
- hdoj_1025
- Android 工程报错解决 Unable to resolve target 'android-17'
- intellij idea 修改背景保护色&&修改字体&&快捷键大全
- 整合之道--Spring4整合Ehcache2.10
- Java排序五:归并排序
- 二维码
- 10020---过滤选择器
- 模式的秘密——单例模式
- iOS 基础 (一)
- 如何使用R来连接各个数据库
- poj3709
- 记录几个和时间有关的方法
- Java排序七:快排