快速排序

时间:2014-05-26 02:47:34   收藏:0   阅读:409

快速排序也利用了分治的思想,跟归并排序排序相比减少了交换次数

bubuko.com,布布扣
int partition(int a[],int p,int r)
{
    int x = a[r];
    int i = p-1;
    int j;
    for(j = p;j<r;j++)
    {
        if(a[j]<=x)
        {
            i++;
            int t = a[i];
            a[i] = a[j];
            a[j] = t;
        }
    }
    int tmp = a[i+1];
    a[i+1] = a[r];
    a[r] = tmp;
    
    return i+1;
}
void quicksort(int a[],int p,int r)
{
    if(p<r)
    {
        int q = partition(a, p, r);
        quicksort(a, p, q-1);
        quicksort(a, q+1, r);
    }
}
bubuko.com,布布扣

 

快速排序,布布扣,bubuko.com

原文:http://www.cnblogs.com/cliviazhou/p/3749344.html

评论(0
© 2014 bubuko.com 版权所有 - 联系我们:wmxa8@hotmail.com
打开技术之扣,分享程序人生!