轻松学算法

算法-快速排序

2016-11-16  本文已影响41人  xietao3

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

前言

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

核心思想

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

示例

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


    快速排序-基数.png

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 )。

结语

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

上一篇 下一篇

猜你喜欢

热点阅读