您的位置:首页 > 产品设计 > UI/UE

快速排序法QuickSort

2016-04-01 12:25 441 查看
/**
*
* @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);
}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: