void quick_sort(int q[],int l,int r){
if(l>=r) return;
int x=q[l+r>>1],i=l-1,j=r+1;
while(i<j){
do i++; while(q[i]<x);
do j--; while(q[j]>x);
if(i<j) swap(q[i],q[j]);
}
quick_sort(q,l,j);
quick_sort(q,j+1,r);
}
快速排序:基于分治法
1.确定分界点x(可以是q[ l ],q[ r],q[ l+r>>1 ])
2.调整区间,将小于x的放在数组的左边,大于x的放在数组的右边
3.递归处理左右两边