Java 快速排序算法 演示

Blog is from this site:http://baike.baidu.com/view/19016.htm?fr=ala0_1

 

正文:

 

package com.morningstar.quicksort;

import java.util.Random;

public class QuickSort 
{
	public static void main(String args[])
	{
		Random random=new Random();
		int[] pData=new int[10];
		for(int i=0;i<pData.length;i++){ //随机生成10个排序数
			Integer a =random.nextInt(100);
			pData[i]= a;
			System.out.print(pData[i]+" ");
		}
		System.out.println("\n");
		int left=0;
		int right=pData.length-1;
		Sort(pData,left,right);
		for(int i=0;i<pData.length;i++){
		System.out.print(pData[i]+" ");
		}
		System.out.println(); 
	}
	
	public static int[] Sort(int[] pData, int left, int right)
	{
		int middle,strTemp;
	    int i = left;
	    int j = right;
	    middle = pData[(left+right)/2];
	    do
	    {
		    while((pData[i]<middle) && (i<right))
		    		i++;
		    while((pData[j]>middle) && (j>left))
		    		j--;
		    if(i<=j)
		    {
			    strTemp = pData[i];
			    pData[i] = pData[j];
			    pData[j] = strTemp;
			    i++;
			    j--;
		    }
		    for(int k=0;k<pData.length;k++)
		    {
		    	System.out.print(pData[k]+" ");
		    }
	    	System.out.println();
	    }while(i<j);//如果两边扫描的下标交错,完成一次排序
	    if(left<j)
	    Sort(pData,left,j); //递归调用
	    if(right>i)
	    Sort(pData,i,right); //递归调用
	    return pData;
	} 
}
 

 上次华仔做毕业设计的时候,用到了排序,而这次项目中要做内存排序,看来排序在实际项目中还是比较重要的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值