快速排序

快速排序

思路: 取一个随机值使数组的一边小于等于这个数,一边满足大于大于这个数;

根据这个思路,可以从左边和右边一起往中间遍历,直到两个指针相遇,交换二者的值

实现方法.
1.取一个值x = q[l+r>>2], 定义两个指针 i = l-1,j = r+1;
2.根据思路进行遍历
3.递归处理左右两边

#include <iostream>

using namespace std;

const int N = 100010;
int q[N],n;

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) 
        {
            int a = q[i];
            q[i] = q[j];
            q[j] = a;
        }
    }
    
    quick_sort(q,l,j);
    quick_sort(q,j+1,r);
}

int main()
{
    cin >> 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;
}
原文地址:https://www.cnblogs.com/zcxy/p/12290711.html