/**
*
* @author Administrator
* 功能:交换式排序之快速排序
*/
package com.test1; import java.util.Calendar; public class QuickSort { public static void main(String[] args) {
// TODO Auto-generated method stub //int[] arr = { 1, 6, 0, -1, 9, -100, -90 };
int[] arr = new int[10000];
for (int i = 0; i < arr.length; i++) {
//让程序随机产生一个1 - 10000个数
//Math.random会产生一个0到1的数
arr[i] = (int)(Math.random()*10000);
}
Quick quick = new Quick(); //在排序前打印系统时间
//Calendar是单开模式,在系统里面只有一个,且只需要一个实例,不是new 出来的
//Java共有23中模式
Calendar cal = Calendar.getInstance();
System.out.println("排序前:"+cal.getTime()); quick.sort(0, arr.length-1, arr); //在排序后打印系统时间
//因为是单开的,所有首先重新得到实例
cal = Calendar.getInstance();
System.out.println("排序后:"+cal.getTime());
// System.out.println("排序后的结果是:");
// for (int i = 0; i < arr.length; i++) {
// System.out.print(arr[i]+" ");
// }
} } //快速排序法
class Quick
{
public void sort(int left, int right, int[] array){ int l = left;
int r= right;
int pivot = array[(left+right)/2];
int temp = 0; while(l < r)
{
while(array[l] < pivot) l++;
while(array[r] > pivot) r--; if(l >= r)
break; temp = array[l];
array[l] = array[r];
array[r] = temp;
} // System.out.println("the current array is");
// for(int i = 0; i< 5; i++)
// {
// System.out.println(" "+array[i]);
// } if(l == r)
{
l++;
r--;
} if(left < r)
sort(left,r,array);
if(right> l)
sort(l,right,array);
} }