时间复杂度 nlogn
快排利用分治思想的原理
主要步骤有以下几种
(1):确认分界点
可以q[l] 可以是q[l+r] 可以是q[r],也可以是随机值
(2):调整区间
将小于等于分界点的,放到左边去,将大于分界点的放到右边去,
(3):递归的处理左右两边
模板代码 注意边界问题 经常来回顾
cpp
#include<iostream>
using namespace std;
const int N= 100010;
int q[N];
void quick_sort(int q[],int l,int r)
{
if( l>=r ) return;
int k = q[(l+r)/2];
int i = l-1, j =r+1;
while(i<j)
{
do i++; while(q[i] < k) ;
do j--; while(q[j] > k) ;
if(i<j)swap(q[i],q[j]);
}
quick_sort(q,l,j);
quick_sort(q,j+1,r);
}
int main()
{
int n;
scanf("%d", &n);
for(int i=0;i<n;i++)
{
scanf("%d",&q[i]);
}
quick_sort(q, 0, n-1);
for(int i=0;i<n;i++)
{
printf("%d ",q[i]);
}
return 0;
}