基础算法| 快速排序 (C++ 和 python实现)

Posted 有理想、有本领、有担当的有志青年

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了基础算法| 快速排序 (C++ 和 python实现)相关的知识,希望对你有一定的参考价值。

文章目录

思想

  1. 确定分界点
  2. 调整区间
  3. 递归处理

思路

确定分界点

  • 选择数组中任意一个数作为分界点
  • 这里选择arr[0]作为分界点

调整区间

  • 分界点左边的数都小于等于分界点,右边的数都大于分界点

递归处理

  • 对剩余数组递归处理,直至完成

模板

C++

void quick_sort(int q[], int l, int r) // r 和 l 为指定需要排序的起始范围

    if (l >= r) return;

    int i = l - 1, j = r + 1, x = q[l + r >> 1];
    while (i < j) // 不能有 = ,否则会陷入死循环
    
        do i ++ ; while (q[i] < x);
        do j -- ; while (q[j] > x);
        if (i < j) swap(q[i], q[j]);
    

    quick_sort(q, l, j);
    quick_sort(q, j + 1, r);

Python

def quick_sort(q, l, r):
    if l >= r:
        return
    i, j, x = l, r, (l + r) >> 1
    while i < j:
        while q[i] < q[x]:
            i += 1
        while q[j] > q[x]:
            j -= 1
        if i < j:
            q[i], q[j] = q[j], q[i]

    quick_sort(q, l, j)
    quick_sort(q, j + 1, r)

    return q

以上是关于基础算法| 快速排序 (C++ 和 python实现)的主要内容,如果未能解决你的问题,请参考以下文章

在最佳情况下,由于堆栈溢出错误,快速排序算法失败 - C++

C++入门:排序之快速排序

排序算法 | 快速排序(含C++/Python代码实现)

快速排序实现 - Python

算法 快速排序 c++语言

区赛第一题讲解+基础算法——桶排序与快速排序