归并排序Java实现
package practice; import edu.princeton.cs.algs4.*;
/*
* 归并排序
* 时间复杂度O(NlgN) N为数组长度
* 归并排序在小数组上表现并不好可以用插入排序代替
*/
public class TestMain {
public static void main(String[] args) {
int[] a = new int[20];
for (int i = 0; i < a.length; i++) {
int temp = (int)(StdRandom.random()*100);
a[i] = temp;
} Merge.sort2(a); for (int i : a) {
System.out.print(i+" ");
}
}
} class Merge{
private static int []anx; //辅助数组
/*
* 自底向上的归并排序(循序渐进)
* 将数字两两分为一组,一直向上归并
* 以下数字表示数组长度,假如要排一个长度为22的数组
* 2 2 2 2 2 2 2 2 2 2 2
* 4 4 4 4 4 2
* 8 8 6
* 16 6
* 22
*/
public static void sort2(int[] a) {
anx = new int[a.length];
for (int sz = 1; sz < a.length; sz += sz) { //将要归并的大小(2*sz)翻倍
for (int lo = 0; lo < a.length - sz; lo += (sz + sz)) { //将数组分为(2*sz)大小的子数组,分别归并
merge(a, lo, lo + sz -1, Math.min(lo + 2*sz -1, a.length - 1));
}
} }
/*
* 自顶向下的归并排序(化整为零)
* 将原数组循环一分为二,直到数组长度为2,再将小数组两两循环归并为原数组
* 以下数字表示数组长度,当被分数字为单数时,前面的数组长度多一
* 22
* 11 11
* 6 5 6 5
* 3 3 2 3 3 3 2 3
* 2 1 2 1 2 1 2 1 2 1 2 1
*/
public static void sort1(int[] a) {
anx = new int[a.length];
sort1(a, 0, a.length - 1);
}
private static void sort1(int []a, int lo, int hi) {
if (lo >= hi) {
return;
}
int mid = lo + (hi - lo)/2; //当被分数字为单数时,前面的数组长度多一
sort1(a, lo, mid); //一分为二归并
sort1(a, mid + 1, hi);
merge(a, lo, mid, hi);
}
/*
* 原地归并
*/
public static void merge(int[] a, int lo, int mid, int hi) {
int m = lo;
int n = mid + 1; //当被分数字为单数时,将最中间的数字归到前面的数组(与上面对应)
int []anx = new int[hi+1];
for (int k = lo; k <= hi; k++) {
anx[k] = a[k]; //将原数组复制到辅助数组
}
//mid将数组分为A,B两部分
for (int k = lo; k <= hi; k++) {
if (m > mid) { //A中取完,将B数组剩余部分存入a[]
a[k] = anx[n++];
}
else if (n > hi) { //B中取完,将A数组剩余部分存入a[]
a[k] = anx[m++];
}
else if (anx[n] < anx[m]) { //A,B中分别取出第一个,比较,并将小数装入a[]
a[k] = anx[n++];
}
else {
a[k] = anx[m++];
}
}
}
}
归并排序动画演示
http://www.cs.usfca.edu/~galles/visualization/ComparisonSort.html
归并排序Java实现的更多相关文章
- 归并排序 求逆序数 链表的归并排序 多线程归并排序 java
import java.util.Scanner; public class Main { private static int count=0; public static void mergeso ...
- 二路归并排序java实现
二路归并排序:其核心思想时将问题一分为二,并递归调用一分为二方法,使问题分割到不能再分各的原子问题,然后再归并,从实现原子问题开始,层层向上归并,最终解决整体问题.即所谓“分而治之,万流归一” 二路归 ...
- 自顶向下(递归)的归并排序和自底向上(循环)的归并排序——java实现
归并排序有两种实现方式,自顶向下和自底向上.前者的思想是分治法,现将数组逐级二分再二分,分到最小的两个元素后,逐级往上归并,故其核心在于归并.后者的思想相反,采用循环的方式将小问题不断的壮大,最后变成 ...
- 单向链表的归并排序——java实现
在做Coursera上的Algorithms第三周测验练习的时候有一道链表随机排序问题,刚开始没有什么思路,就想着先把单向链表归并排序实现了,再此基础上进行随机排序的改造.于是就结合归并排序算法,实现 ...
- 归并排序-java
排序-归并排序 基本思想:是指将两个或两个以上的有序表合并成一个新的有序表. 具体步骤: (1首先将整个表看成是n个有序子表,每个子表的长度为1. (2)然后两两归并,得到n/2个长度为2的有序子表. ...
- leetcode23 多个拍好序的链表进行归并排序 (java版本)
题目: Merge k sorted linked lists and return it as one sorted list. Analyze and describe its complexit ...
- 归并排序java
import java.util.Arrays; public class MergeSort { public static void main(String[] args) { MergeSort ...
- 归并排序—Java版
一开始做算法的时候,感觉递归算法很绕,所以我就在阅读别人代码的基础上,对代码每一步都添加自己的注解,方便我以后的学习. public class MergeSort { /** * 归并排序 * @p ...
- 归并排序——Java实现
一.排序思想 将两个或两个以上的一排序文件合并成一个有序文件的过程叫归并,而归并排序就是建立在归并操作上的一种有效的排序算法,该算法是采用分治法的一个非常典型的应用.将以有序的了序列合并,得到完全有序 ...
随机推荐
- spring入门之环境搭建
本人刚刚接触spring,看了一些教程,但是很多概念都不懂(以前没接触过,看着很抽象),所以我觉得通过动手可能会更好的理解并且掌握.看了一些小实例,但是都没有成功,终于在各种尝试之后搭建成功了,现在我 ...
- WAS 部署 Birt 报表出现 error.CannotStartupOSGIPlatform 和 更新web.xml
在WAS7.0中部署Birt报表会出现error.CannotStartupOSGIPlatform错误,通常需要这样修改 1.依次打开Applications->WebSphere enter ...
- 移动端APP页面Webview模式跳转详解
首先,来看一下关于Android home键和back键区别 back键 Android的程序无需刻意的去退出,当你一按下手机的back键的时候,系统会默认调用程序栈中最上层Activity的Dest ...
- 用u盘装系统,进入bios后没有usb启动项怎么办
开机按DEL进入BIOS(现在还这么说吧,不同的主板进入方法不太一样),找到BOOT选项. 选择Boot mood:legacy support(引导模式,逻辑支持) boot priorty:leg ...
- JavaScript高程--<script>标签
<script>标签 在HTML5中script主要有以下几个属性:async,defer,charset,src,type, async(可选): 关键词:异步脚本,外部文件,立即下载: ...
- 打造颠覆你想象中的高性能,轻量级的webform框架---无刷新提交后台并返回参数(第五天)
问题5: 使用aspx 页面执行后台方法,总是要刷新整个页面?我想提交后台不刷新页面,同时返回参数 执行前台的js 脚本,就是说类似于像 ajax 的效果一样,那我们该怎么做呢? 大家是否已经看了前 ...
- Angular 小试牛刀[1]:Getting Started
首先,Angular2 与 Angular1.x 版本没有多大关系,甚至可以说是两个完全不一样的框架,故 Angular 指的是 Angular2 及以上的版本.而 Angular 与 TypeScr ...
- 纯JavaScript实现异步Ajax的基本原理
Ajax实际就是XMLHttpRequest对象和DOM.(X)HTML和CSS的简称,用于概括异步加载页面内容的技术. Ajax实例 HTML代码如下,包含一个h5标题和一个按钮: JS代码如下 ...
- Oracle外键需要建索引吗?
关于Oracle中的外键,首先要说明一下. 1. 除非已定义了父表主键或唯一键约束,否则oracle将不允许创建子表的外键约束. 2. 在定义外键约束时,oracle不会自动创建索引,所以必须手动在与 ...
- Ubuntu无法访问windows分区
正常情况: 重启, 先进入windows, 再重启进入Ubuntu(一定是重启, 先关机再进Ubuntu没用). 异常情况: sudo ntfsfix /dev/sda5(或6或7,得看哪个盘无法访问 ...