(1)首先设定一个分界值,通过该分界值将数组分成左右两部分。
(2)将大于或等于分界值的数据集中到数组右边,小于分界值的数据集中到数组的左边。此时,左边部分中各元素都小于分界值,而右边部分中各元素都大于或等于分界值。
(3)然后,左边和右边的数据可以独立排序。对于左侧的数组数据,又可以取一个分界值,将该部分数据分成左右两部分,同样在左边放置较小值,右边放置较大值。右侧的数组数据也可以做类似处理。
(4)重复上述过程,通过递归将左侧部分排好序后,再递归排好右侧部分的顺序。当左、右两个部分各数据排序完成后,整个数组的排序也就完成了。
1)设置两个变量i、j,排序开始的时候:i=0,j=N-1;
2)以中间数组元素作为关键数据,赋值给t,即t=a[(l+r)/2];
3)从i开始向后搜索,即由前开始向后搜索(i++),找到第一个大于t的值
4)从j开始向前搜索,即由后开始向前搜索(j--),找到第一个小于t的值
5)重复第3、4步,直到i==j。
代码实现如下:
#include<iostream>
using namespace std;
void quick_sort(int a[],int l,int r){
//若只剩一个数则直接返回
if(l>=r) return;
//i存放左侧下标,j存放右侧下标
//t存放分界值,这里采用数组中间的数作为分界值
int i=l-1,j=r+1;
int t=a[(l+r)/2];
//自左向右寻找第一个比分界值大的数
//自右向左寻找第一个比分界值小的数
//若这两数下标不相同则交换
//交换后若i<j,说明数组未遍历完,继续循环
while (i<j)
{
do i++;while (a[i]<t);
do j--;while (a[j]>t);
if (i<j) swap(a[i],a[j]);
}
//在完成上述循环后数组会以分界值为界分为左右两部分
//左侧都比分界值小,右侧都比分界值大
//但是左右两侧内部并不有序,通过递归继续排序
quick_sort(a,l,j);
quick_sort(a,j+1,r);
}
int main(){
int temp[100]={0};
int num=0;
cin>>num;
for(int i=0; i<num; i++) cin>>temp[i];
quick_sort(temp,0,num-1);
for(int i=0; i<num; i++) cout<<temp[i]<<" ";
return 0;
}