Hero-oo

Hero-oo

email

【排序】快速排序

〇、思想#

  • 分治

一、步骤#

  1. 在数组中选择一个基准 base,将原始数组分为【小于 base】- base -【大于 base】
  2. 对【小于 base】、【大于 base】两个数组分别重复步骤 1、2,直到排序完成

快速排序

二、实现#

void my_qsort(short *arr, int start, int end)
{
    if (start >= end) {
        return;
    }

    int i = start;
    int j = end;
    int base = arr[start];
    
    while (i < j) {
        while (arr[j] >= base && i < j) {
            j--;
        }
        while (arr[i] <= base && i < j) {
            i++;
        }
        if (i < j) {
            int tmp = arr[i];
            arr[i] = arr[j];
            arr[j] = tmp;
        }
    }
    arr[start] = arr[i];
    arr[i] = base;

    my_qsort(arr, start, i - 1);
    my_qsort(arr, j + 1, end);
}

三、性能分析#

最坏情况#

如果每次选择的元素 base 都是要排序元素的最大 / 最小元素,则数组每次排序后确定一个元素的位置,耗时:$\theta (n)$,然后递归对一个 n-1 个元素和一个 0 个元素的数组进行快排。运行时间为:$T (n) = T (n-1)+T (0)+\theta (n)$
得时间复杂度为:$O (n^2)$

最好情况#

每次选择的元素都是数组中间的元素,则数组每次排序后确定一个元素的位置,耗时:$\theta (n)$,然后递归对两个 n/2 的元素进行快排。运行时间为 $T (n) = 2T (n/2)+\theta (n)$
得时间复杂度为:$O (nlogn)$

平均情况#

快排的平均运行时间接近于最好的情况,也就是 $O (nlogn)$

四、优化#

  1. 快排中基准 base 的选择会直接影响性能。为此,可以加一个随机化选取来优化快排
  2. 对于小数组排序,可以使用其他方法排序
  3. 使用迭代而非递归

Done!

此文由 Mix Space 同步更新至 xLog
原始链接为 https://www.vikifish.com/posts/algo/qsort


加载中...
此文章数据所有权由区块链加密技术和智能合约保障仅归创作者所有。