快速排序

#include<iostream>
using namespace std;

void quick_sort(int a[],int left,int right){

	//终止条件——————————————————————————————————1
	if(left>=right)
		return ;
	

	//关键代码——————————————————————————————————2
	
	int pivot=a[left];	//pivot作为枢纽,比pivot大的数在左侧,小于pivot的数置于右侧。
	int i=left,j=right;
	
	while (i<j)	{//关键性循环,一个萝卜一个坑。右→左(--j);左→右(++i)。。。
		while(i<j && a[j]>=pivot) --j;
		if (i<j){	
			a[i]=a[j];//a[i]=a[j]后,a[j]的值就可以被后续的a[i]覆盖了
			++i;//a[i]处目前为小于pivot的原a[j]的值,i需要右移一位
		}

		while(i<j && a[i]<=pivot) ++i;
		if(i<j){
			a[j]=a[i];//a[j]=a[i]后,a[i]的值就可以被后续的a[j]覆盖了
			++j;//a[j]处目前为大于pivot的原a[i]的值,j需要左移一位
		}

	}
	a[i]=pivot;//while循环结束时i==j,找到pivot的坑。
	
	//分治————————————————————————————————————3
	quick_sort(a,left,i-1);
	quick_sort(a,i+1,right);
}

int main(){
	int array[]={6, 3, 5, 7, 2, 4, 1, 8, 10, 9};
    quick_sort(array,0,sizeof(array)/sizeof(array[0]) -1);
    for(int i=0;i<sizeof array/sizeof array[0];i++)
        cout<<array[i]<<" ";
    cout<<endl;
	return 0;
}

原文地址:https://www.cnblogs.com/sjw1357/p/3864007.html