快速排序

作者: 卡布萨岛 | 来源:发表于2018-10-18 10:13 被阅读0次

快速排序

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

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

代码:

在此代码中,函数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)。

总结:

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

相关文章

  • 七大排序算法之快速排序

    七大排序算法之快速排序 @(算法笔记)[排序算法, 快速排序, C++实现] [TOC] 快速排序的介绍: 快速排...

  • 面试准备--排序

    堆排序 快速排序(simple) 快速排序(regular) 归并排序 Shell排序 插入排序 选择排序 冒泡排序

  • 排序

    插入排序 选择排序 冒泡排序 归并排序 快速排序* 三路快速排序

  • 算法笔记01-排序#2

    快速排序敢叫快速排序,那它一定得快。 快速排序 概述 快速排序也是分治排序的典型,它快,而且是原地排序。不过,要防...

  • PHP 实现快速排序

    导语 这篇了解下快速排序。 快速排序 快速排序(英语:Quicksort),又称划分交换排序(partition-...

  • 快速排序的Python实现

    目录 快速排序的介绍 快速排序的Python实现 快速排序的介绍 快速排序(quick sort)的采用了分治的策...

  • 数据结构与算法 快速排序

    起因:快速排序,又称分区交换排序,简称快排,之前没有了解过,抽空学习一下。 快速排序 1 快速排序 快速排序的定义...

  • 数组-快速排序

    采用快速方式对数组进行排序 快速排序百科:快速排序(Quicksort)是对冒泡排序算法的一种改进.快速排序是通过...

  • OC数据结构&算法

    更多整理资料尽在?一平米小站 目录 选择排序 冒泡排序 插入排序 快速排序 双路快速排序 三路快速排序 堆排序 选...

  • 要成功就做一百题-94

    题目名称 今天来几个排序,都是经典题目,包括带拆分的快速排序,堆排序,归并排序。 描述 快速排序快速排序核心就是分...

网友评论

    本文标题:快速排序

    本文链接:https://www.haomeiwen.com/subject/rdhjzftx.html