算法-快速排序

这个排序算法的命名有点随意啊,这种态度怎么行

前言

这个算法感觉脱离了简单算法的范畴,脑袋稍微要转那么一点儿弯,排序代码倒是多了不少。

核心思想

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

示例

  1. 首先,我们枪打出头鸟,把第一个数10给拎出来,留下一个坑位(坑位很重要*),做参照物:基数。


    快速排序-基数.png
  • 有了基数之后,我们建立左右指针各一个,分别放在最左边和最右边的位置,右指针逐个对比,遇到比基数小的值就停下,很巧的是,右边第一个数就比基数小。


    快速排序-右指针 .png
  • 找到比基数10小的值:3,把3挪到空出来的坑位中,3被取走从而留下了新坑,右指针的位置停留在该处,下一次从这里开始向左查找。


    快速排序-填坑.png
  • 右指针操作结束后,左指针从左边开始出发,左指针要找到比基数:10更大的数,然后把这个数放进坑里。


    快速排序-左指针.png
  • 左指针找到了比基数大的值:11,将11放入坑位,并且留下新坑,左指针的位置停留在该处,下一次从这里开始向右查找。


    快速排序-左指针对比.png
  • 左指针结束行动,又轮到右指针,右指针从原地出发,操作和之前一致。


    右指针-再次出发.png
  • 左右指针间隔调用


    快速排序-左指针再次出发.png
  • 直至左右指针相遇


    快速排序-左右指针相遇.png
  • 最后我们以基数为中心得到左右两边两组数据{3,5,3,1,7,6,8,10}和{33,11},然后再将这两组数据分别进行递归排序,再分出子集也是如此。

C语言代码

#pragma mark - 快速排序
int partition(int arr[], int len, int left, int right) {
    int baseNum = arr[left];
    // 坑位
    int baseIndex = left;
    printf("baseNum:%d\n",baseNum);
    // 左右查找指针不相交
    while (left<right) {
        // 从右向左 找到大于等于基数的值
        while (left<right && arr[right]>=baseNum) {
            right--;
        }
        // 找到后填坑
        arr[baseIndex] = arr[right];
        // 留出新坑
        baseIndex = right;
        printf("调整1\n");
        printfArr(arr, len);

        // 从右向左 找小于等于基数的值
        while (left<right && arr[left]<=baseNum) {
            left++;
        }
        // 找到填坑
        arr[baseIndex] = arr[left];
        // 留出新坑
        baseIndex = left;
        printf("调整2\n");
        printfArr(arr, len);

        
    }
    // 基数填最后一个坑
    arr[baseIndex] = baseNum;
    return baseIndex;
}

void fastSort (int arr[], int len, int left, int right) {
    if (left<right) {
        printf("调整前\n");
        printfArr(arr, len);
        
        int baseIndex = partition(arr, len, left, right);
        
        printf("调整3\n");
        printfArr(arr, len);

        
        fastSort(arr, len, left, baseIndex-1);
        fastSort(arr, len, baseIndex+1, right);

    }else{
        printf("结束\n");
        printfArr(arr, len);
    }
}

时间复杂度

快速排序是不稳定的,排序时间平均时间复杂度是O ( nlgn )。

结语

在学习算法的过程中,整个思维沉浸进去,直至水落石出的时候,感觉像给大脑做了一个健身操。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,490评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,581评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,830评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,957评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,974评论 6 393
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,754评论 1 307
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,464评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,357评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,847评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,995评论 3 338
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,137评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,819评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,482评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,023评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,149评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,409评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,086评论 2 355

推荐阅读更多精彩内容

  • 数据结构与算法——快速排序 快速排序,顾名思义,它速度很快,针对一般应用中各种不同的输入都要比其他排序算法快很多,...
    sunhaiyu阅读 3,280评论 0 3
  • 前言 快速排序由于排序效率在同为O(N*logN)的几种排序方法中效率较高,因此经常被采用,再加上快速排序思想--...
    fjytqiu阅读 2,220评论 0 3
  • 青峰科技19小时前快速排序算法是分治算法技术的一个实例,也称为分区交换排序。快速排序采用递归调用对元素进行排序,是...
    不二王1006阅读 661评论 0 50
  • 快速排序算的上目前使用最广泛的算法了,之所以它这么受欢迎,是因为它是原地排序,而且将长度为 N 的数组排序所需的时...
    ghwaphon阅读 1,609评论 2 18
  • 有人甚至将快排称为分治法,但分治更多应该指明是一种思想,而非具体的排序算法。对于快速排序的内容,我这样概括:每趟排...
    郝翔阅读 711评论 0 2