快速排序

快速排序

通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。

注意:每次都是右哨兵先出发,且左哨兵大于右哨兵时结束

代码:

在此代码中,函数quickSort()中左哨兵是i,left,右哨兵是j,right

#include <stdio.h>

void quickSort(int *a,int left,int right)
{
    int i,j,t,temp;
    if(left > right)//左哨兵大于右哨兵结束
        return;
    temp = a[left]; //存储基准数
    
    i = left;
    j = right;
    while(i != j)
    {
        //先右哨兵出发
        while(a[j] >= temp && i < j)
            j--;
        //在左哨兵出发
        while(a[i] <= temp && i < j)
            i++;
        
        //找到后交换两个数在数组中的位置
        if(i < j)//首先需要判断哨兵i和哨兵j没有相遇
        {
            t = a[i];
            a[i] = a[j];
            a[j] = t;
        }
        
    }
    
    //最后将基准树归位
    a[left] = a[i];
    a[i] = temp;
    
    //递归处理
    //i-1.i+1是因为i现在是基准点,需要排除
    quickSort(a,left,i - 1);
    quickSort(a,i + 1,right);
}

int main(void)
{
    int i;
    int a[10] = {5,8,2,6,0,1,4,7,3,9};
    printf("Front:");
    for(i = 0;i < 10;i ++)
        printf("%d ",a[i]);
    quickSort(a,0,9);
    printf("\nBack: ");
    for(i = 0;i < 10;i ++)
        printf("%d ",a[i]);
    getchar();
}

运行结果:

Front:5 8 2 6 0 1 4 7 3 9
Back: 0 1 2 3 4 5 6 7 8 9

时间复杂度:

最差时间复杂度和冒泡排序是一样: O(N²),
平均时间复杂度为 :(NlogN)。

总结:

快速排序之所以比较快,是因为相比冒泡排序,每次交换是跳跃式的,每次排序的时候设置一个基准点,将小于基准点的数全部放到基准点的左边,将大于基准点的数全部放到基准点的右边。这样在每次交换的时候就不会像冒泡排序一样只能在相邻的数之间进行交换,交换的距离就大的多,因此总的比较和交换次数就少,速度自然就提高了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 快速排序(Quicksort)是对冒泡排序的一种改进。 快速排序由C. A. R. Hoare在1962年提出。它...
    Aroli阅读 2,174评论 0 6
  • 上一节的冒泡排序可以说是我们学习的第一个真正的排序算法,并且解决了桶排序浪费空间的问题,但在算法的执行效率上却牺牲...
    青葱烈马阅读 737评论 0 1
  • 假设我们现在对“6 1 2 7 9 3 4 5 10 8”这个10个数进行排序。首先在这个序列中随便...
    小陈阿飞阅读 1,030评论 0 1
  • 高快省的排序算法 有没有既不浪费空间又可以快一点的排序算法呢?那就是“快速排序”啦!光听这个名字是不是就觉得很高端...
    博弈史密斯阅读 466评论 0 0
  • 算法的精髓在于,跟它一比高数也显得那么生动活泼…。本文由啊哈磊吐槽而成,话说我还是头一次见到这么萌的变量,简直颠覆...
    高浩浩浩浩浩浩阅读 643评论 0 2

友情链接更多精彩内容