public class MergeSort {

	private static void mergeSortTest() {
int[] in = { 2, 5, 3, 8, 6, 7, 1, 4, 0, 9 };
Utils.printArray("归并排序前:",in);
int a[] = mergeSort(in);
Utils.printArray("归并排序后:",a);
} private static int[] mergeSort(int[] arr) {
if (arr.length == 1) {
return arr;
} else {
int[] arrL = new int[arr.length / 2];
int[] arrR = new int[arr.length - arr.length / 2];
int mid = arr.length / 2;
for (int i = 0; i < mid; i++) {
arrL[i] = arr[i];
}
for (int i = mid, j = 0; i < arr.length; i++, j++) {
arrR[j] = arr[i];
}
int[] sortedArrL = mergeSort(arrL);
int[] sortedArrR = mergeSort(arrR);
int[] resultArr = mergeTwoArr(sortedArrL, sortedArrR);
return resultArr;
}
} private static int[] mergeTwoArr(int[] arrL, int[] arrR) {
int i = 0, j = 0;
int[] arrTmp = new int[arrL.length + arrR.length];
int foot = 0;
while (i < arrL.length && j < arrR.length) {
if (arrL[i] <= arrR[j]) {
arrTmp[foot++] = arrL[i++];
} else {
arrTmp[foot++] = arrR[j++];
}
}
if (i == arrL.length) {
while (j < arrR.length) {
arrTmp[foot++] = arrR[j++];
}
} else {
while (i < arrL.length) {
arrTmp[foot++] = arrL[i++];
}
}
return arrTmp;
} public static void main(String[] args) {
mergeSortTest();
}
}

  

java排序算法-归并排序的更多相关文章

  1. Java排序算法——归并排序

    import java.util.Arrays; //================================================= // File Name : MergeSor ...

  2. java排序算法(九):归并排序

    java排序算法(九):归并排序

  3. java排序算法(一):概述

    java排序算法(一)概述 排序是程序开发中一种非常常见的操作,对一组任意的数据元素(活记录)经过排序操作后,就可以把它们变成一组按关键字排序的一组有序序列 对一个排序的算法来说,一般从下面三个方面来 ...

  4. java排序算法(四):冒泡排序

    java排序算法(四):冒泡排序 冒泡排序是计算机的一种排序方法,它的时间复杂度是o(n^2),虽然不及堆排序.快速排序o(nlogn,底数为2).但是有两个优点 1.编程复杂度很低.很容易写出代码 ...

  5. Java排序算法(三)

    Java排序算法(三) 三.Java排序算法总结 从这三组时间复杂度对比中,可以看出,堆排序和归并排序是不管在什么情况下发挥稳定的,快速排序好的时候表现如天才,坏情况下比较差强人意,甚至在等待排序个数 ...

  6. Java排序算法(二)

    java排序算法(二) 二.改进排序算法 2.1希尔排序 定义:希尔排序(ShellSort)是插入排序的一种.也称缩小增量排序,是直接插入排序算法的一种更高效的改进版本.希尔排序是非稳定排序算法. ...

  7. Java排序算法(一)

    Java排序算法(一) 排序的基本概念和分类 1.1排序的定义 在<大话数据结构>中,排序定义为,假设含有n个记录的序列为{r1,r2,...,rn},其相应的关键字{k1,k2,..., ...

  8. Java排序之归并排序

    Java排序之归并排序 1. 简介 归并排序的算法是将多个有序数据表合并成一个有序数据表.如果参与合并的只有两个有序表,则成为二路合并.对于一个原始的待排序数列,往往可以通过分割的方法来归结为多路合并 ...

  9. java排序算法之冒泡排序和快速排序

    总结一下Java排序算法,以便记忆. 各类排序的时间复杂度: 排序方法 时间复杂度(平均) 时间复杂度(最坏) 时间复杂度(最好) 空间复杂度 稳定性 复杂性 直接插入排序 O(n2)O(n2) O( ...

随机推荐

  1. Rx 入门 示例

    首先写一个观察者模式 public interface Watcher { public void update(String str); } public class ConcreteWatcher ...

  2. Windows Azure上的Odoo(OpenERP)-1.创建Ubuntu虚拟机,安装PostgreSQL 数据库

    前提是您必须拥有Windows Azure的账号,如果没有的话,可以去Windows Azure 中国区网站申请免费试用账号.哈哈,我就是第一批申请的试用账号,感觉自己挺幸运的.申请的过程就不写了,请 ...

  3. CentOS6.6x86_64 部署 Nginx1.62+MySQL5.6.20+PHP5.6.4

    准备工作 切换到管理员身份 su - 安装编译扩展 yum install -y gcc-c++ 创建数据库目录.代码目录 mkdir /mnt/data /mnt/www 安装Nginx 1.6.2 ...

  4. C# Word常用操作(转)格式设置

    一.word文档表格操作.分页及换行 //合并单元格table.Cell(2, 2).Merge(table.Cell(2, 3)); //单元格分离 object Rownum = 2;object ...

  5. mssql的holdlock锁跟索引的关系

    表锁tablock是会给表所有数据附加共享锁,但是只是当前语句有效,语句执行完毕,锁释放,而不会持续到事务结束,而tablockX表锁是持续到事务结束的锁 holdlock锁,锁定的范围会根据wher ...

  6. Xcode 的正确打开方式——Debugging(转)

    转自CocoaChina http://www.cocoachina.com/ios/20150225/11190.html 程序员日常开发中有大量时间都会花费在 debug 上,从事 iOS 开发不 ...

  7. java_reflect_01

    最近学习java开始接触到了框架,突然觉得java反射很重要,因此在这里做了一些总结(参考园中大苞米大神的文章) 首先我们要认识一下Class: 一.Class类有什么用? class类的实例表示ja ...

  8. MySql奇葩问题汇总

    当字段名与关键词重叠时,sql语句中用``将字段名括起来,就可解决报错的问题.

  9. Adb shell 常用命令

    1. 查看IP adb shell netcfg 2. 查看挂载设备 adb devices 3. 将本地端口转发至手机端口 adb forward tcp: tcp: // PC上所有6100端口通 ...

  10. javascript知识图谱