Quick Sort

 QuickSort

基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。

代码:

#include<iostream>
using namespace std;

int partition(int a[],int low,int high)              //大于pivot的位于pivot右侧,小于pivot的位于左侧
{
	int pivot=a[low];
	while(low<high)
	{
	   while(low<high&&a[high]>=pivot)
		--high;
	   a[low]=a[high];
	   while(low<high&&a[low]<=pivot)
		++low;
	   a[high]=a[low];
	}
	a[low]=pivot;
	return low;
}

void QSort(int a[],int low,int high)                //递归,二分
{
	if(low<high)
	{
	   int pivot=partition(a,low,high);
	   QSort(a,low,pivot-1);
	   QSort(a,pivot+1,high);
	}
}
int main()                                          //测试
{
	int a[]={3,12,44,5,53,61,67,84,7,88,90};
	int length=11;
	QSort(a,0,length-1);
	for(int i=0;i<length;i++)
		cout<<a[i]<<' ';
	getchar();
	return 0;
}


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值