java 归并排序

原创 2013年12月06日 11:46:47

内部排序之归并排序

public class MergeSort {
	/**
	 * 归并排序
	 * @param <T>
	 * @param a
	 * @param b临时数据
	 * @param start要排序数据起始地址
	 * @param end数据结束地址
	 */
	public static <T extends Comparable<? super T>> void merger(T [] a,T [] b,int start,int end){
		if(start==end) return;
		
		int middle=(start+end)/2;
		//分成前后两部分后递归调用
		merger(a, b,start,middle);
		merger(a, b,middle+1,end);
		//将排序好的前后两部分再排序
		proccoss(a,b,start,middle+1,end);
	}
	/**
	 * 排序好的前后两部分再排序
	 * @param <T>
	 * @param a要排序的数据
	 * @param b临时数据组
	 * @param pos1要排序数据的起始地址
	 * @param pos2后半部分数据的起始地址(也是前一部分数据结束地址减1的位置)
	 * @param end后半部分数据的结束地址
	 */
	public static <T extends Comparable<? super T>> void proccoss(T [] a,T [] b,int pos1,int pos2,int end){
		int bpos=pos1;
		int tmp1=pos1;
		int tmp2=pos2;
		while(pos1<tmp2&&pos2<=end){
			//将前后两部分中较小的数据放到临时数组相应的位置,同时对应的指针后移一位
			if(a[pos1].compareTo(a[pos2])<0){
				b[bpos++]=a[pos1++];
			}else{
				b[bpos++]=a[pos2++];
			}
		}
		//如果其中的某一部分数据已经全部放到临时数字b中,那么将另一部分数据中剩余部分拷贝到临时数组中
		if(pos1==tmp2){
			for(int i=pos2;i<=end;i++){
				b[bpos++]=a[pos2++];
			}
		}else{
			for(int i=pos1;i<tmp2;i++){
				b[bpos++]=a[pos1++];
			}
			
		}
		//将临时数组中的数据拷贝回原数组
		for(int i=tmp1;i<=end;i++){
			a[i]=b[i];
		}
	}
	
	public static void main(String[] args) {
		Integer a []={8,6,9,2,5,100,25,48,1,6,8,46,7864,54,111};
		merger(a,new Integer[a.length],0,a.length-1);
		for(int i=0;i<a.length;i++){
			System.out.print(a[i]+",");
		}
		
	}
}


Java单链表归并排序

概念归并排序是建立在归并操作上的一种有效的排序算法。该算法是采用分治法(Divide and Conquer)的一个非常典型的应用,归并排序将两个已排序的表合并成一个表。归并排序基本原理通过对若干个有...
  • bug_moving
  • bug_moving
  • 2017年02月24日 08:53
  • 1291

排序算法Java实现——归并排序

归并排序(也可以叫合并排序),其实归并排序的本质就是合并排序。 它是与插入排序、交换排序、选择排序不同的一类排序方法,不同之处在于: 它要求:待排序序列是由若干个有序子序列组成。 那么究竟什么是归并排...
  • singit
  • singit
  • 2017年04月25日 22:09
  • 751

[排序算法]--归并排序的Java实现

归并排序(2-路归并):归并排序是建立在归并操作上的一种有效的排序算法。该算法是采用分治法(Divide and Conquer)的一个非常典型的应用,归并排序将两个已排序的表合并成一个表。 下面先看...
  • u010853261
  • u010853261
  • 2017年02月06日 16:14
  • 1181

算法导论:归并排序java实现

这是归并排序的部分代码,个人认为归并排序作为算法课的前导算法算是一个比较难的问题因为他涉及到了我们都比较恐惧的递归运算。说到递归我们都是非常头疼的,但是递归较其他用迭代来实现的算法又算是理解起来比较简...
  • xidian_db
  • xidian_db
  • 2015年03月30日 16:33
  • 390

归并排序的递归与非递归实现Java

public static int[] sort(int[] nums, int low, int high) { int mid = (low + high) / 2; ...
  • lll1204019292
  • lll1204019292
  • 2016年08月28日 16:20
  • 490

【Java常用排序算法】归并排序(二路归并排序)

归并排序 二路归并排序 Java实现
  • donggua3694857
  • donggua3694857
  • 2017年02月27日 23:17
  • 1838

【排序算法】归并排序原理及Java实现

归并排序就是利用归并的思想实现的排序方法。而且充分利用了完全二叉树的深度特性,因此效率比较高。其基本原理如下:对于给定的一组记录,利用递归与分治技术将数据序列划分成为越来越小的半子表,在对半子表排序,...
  • jianyuerensheng
  • jianyuerensheng
  • 2016年04月27日 17:35
  • 13440

归并排序算法原理及JAVA实现

基本思想:归并(Merge)排序法是将两个(或两个以上)有序表合并成一个新的有序表,即把待排序序列分为若干个子序列,每个子序列是有序的。然后再把有序子序列合并为整体有序序列。递归形式的算法在形式上较简...
  • xuxurui007
  • xuxurui007
  • 2012年06月11日 23:10
  • 982

归并排序三种实现方法(递归、非递归和自然合并排序)

1.      递归实现归并排序 1)     基本思想: 将待排元素分成大小大致相同的2个子集,分别对2个子集合进行排序,最终将排好序的子集合合并 就会得到一个排好序的集合 即为所求 设归并排...
  • niuxiunan
  • niuxiunan
  • 2013年04月06日 23:28
  • 4461

选择,插入,希尔,快速,堆,归并排序六种排序方式的Java 实现和性能对比(付代码)

代码见:   https://github.com/Turtledove/EnHanceExercises/tree/master/EnHanceExercises/src 待续...
  • yunshuixiliu
  • yunshuixiliu
  • 2014年03月11日 14:49
  • 1391
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:java 归并排序
举报原因:
原因补充:

(最多只允许输入30个字)