快速排序

注,代码是从网上down的,本人做了思想和关键语句的注释



package com.sufa.test;

public class QuickSort {

	/*
	 * 快速算法
	 * 取一个key值,将序列分为左区间、右区间,其中左区间的数均小于key值,右区间的数均大于key值
	 * 递归对左区间和右区间进行排序
	 * */
	public static void QuickSort(int[] pData, int left, int right) {
		int i, j;
		int middle, temp;
		i = left;
		j = right;
		
		//选取第一个值作为中间值
		middle = pData[left];
		
		while (true) {
			//过滤掉左边比key值小的数
			while ((++i) < right - 1 && pData[i] < middle)
				;
			//过滤掉右边比key值大的数
			while ((--j) > left && pData[j] > middle)
				;
			//设置边界条件
			if (i >= j)
				break;
			
			//调整两个区间的值,或者将右区间的大值调到左边,或者将左区间的小值调到右边
			temp = pData[i];
			pData[i] = pData[j];
			pData[j] = temp;
		}
		
		//将KEY值放入适当的位置
		pData[left] = pData[j];
		pData[j] = middle;

		//分别对左右区间进行递归快速排序
		if (left < j)
			QuickSort(pData, left, j);

		if (right > i)
			QuickSort(pData, i, right);
	}

	public static void main(String[] args) {
		int[] pData = new int[10];
		for (int i = 0; i < 10; i++)
			pData[i] = (int) (Math.random() * 100);

		for (int i = 0; i < pData.length; i++)
			System.out.print(pData[i] + " ");

		QuickSort(pData, 0, pData.length);

		System.out.println("\n***********************");

		for (int i = 0; i < pData.length; i++)
			System.out.print(pData[i] + " ");
	}

}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值