首页 > 编程语言 > 详细

Java快速排序 分别以数组0位作为基准 和最后一位作为基准的排序演示

时间:2015-05-31 23:01:53      阅读:426      评论:0      收藏:0      [点我收藏+]
package util;

public class Pub {
	
	public static void beforeSort(int[] arr){
		System.out.println("before sort: ");
		for(int i:arr){
			System.out.print(i+" ");
		}
		System.out.println();
	}
	public static void afterSort(int[] arr){
		System.out.println("after sort: ");
		for(int i:arr){
			System.out.print(i+" ");
		}
	}

}

  以0位为基准 代码如下:

package swap;

import java.util.Arrays;

import util.Pub;

public class FastSort {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		 int[] a={1,38,65,97,76,13,27};
		 Pub.beforeSort(a);
		 quick(a);
		 Pub.afterSort(a);
	}
	
	private static int getMiddle(int[] arr,int left,int right){
			int base=arr[left];  //关键一点 当从左边第一个数作为基数的时候,先从右边开始判断
			while(left<right){
				while(left<right&&arr[right]>=base){
					right--;
				}
				arr[left]=arr[right];
				while(left<right&&arr[left]<=base){
					left++;
				}
				arr[right]=arr[left];
			}
			arr[left]=base;
			return left;
			//System.out.println(left);
	}
	
	private static void quickSort(int[] a, int low, int high) {
        if(low<high){ //如果不加这个判断递归会无法退出导致堆栈溢出异常
            int middle = getMiddle(a,low,high);
            quickSort(a, 0, middle-1);
            quickSort(a, middle+1, high);
        }
    }
	 private static void quick(int[] a) {
	        if(a.length>0){
	            quickSort(a,0,a.length-1);
	        }
	    }

}

  运行结果:

before sort: 
1 38 65 97 76 13 27 
after sort: 
1 13 27 38 65 76 97 

  以末尾为基准,代码如下:

package swap;

import java.util.Arrays;

import util.Pub;

public class FastSortReverse {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		 int[] a={1,38,65,97,76,13,27};
		 Pub.beforeSort(a);
		 quick(a);
		 Pub.afterSort(a);
	}
	
	private static int getMiddle(int[] arr,int left,int right){
		 //  关键一点 选数组哪边开始作为基数点进行比较,需要从另一头开始进行判断,否则会进行错误的替换。
			int base=arr[right]; 
			while(left<right){
				while(left<right&&arr[left]<=base){
					left++;
				}
				arr[right]=arr[left];
				while(left<right&&arr[right]>=base){
					right--;
				}
				arr[left]=arr[right];
			}
			//因为这种方法 总是会将最初的base基准数字覆盖掉,所以 需要找到合适的地方,放入基准数字。
			arr[left]=base;
			return left;
			//System.out.println(left);
	}
	
	private static void quickSort(int[] a, int low, int high) {
        if(low<high){ //如果不加这个判断递归会无法退出导致堆栈溢出异常
            int middle = getMiddle(a,low,high);
            quickSort(a, 0, middle-1);
            quickSort(a, middle+1, high);
        }
    }
	 private static void quick(int[] a) {
	        if(a.length>0){
	            quickSort(a,0,a.length-1);
	        }
	    }

}

  运行结果:

before sort: 
1 38 65 97 76 13 27 
after sort: 
1 13 27 38 65 76 97 

  

 

Java快速排序 分别以数组0位作为基准 和最后一位作为基准的排序演示

原文:http://www.cnblogs.com/IamThat/p/4542783.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!