快速排序算法

快速排序算法

快速排序是一种高效的排序算法,其基本思想是通过一趟排序将待排记录分隔成独立的两部分,其中一部分记录的关键字均比另一部分的关键字小,然后分别对这两部分继续进行排序,直到整个序列有序。

优点:

时间效率高:平均时间复杂度为O(n log n),在大多数情况下表现良好。

空间复杂度相对较低:原地排序,不需要额外的存储空间。

对大规模数据排序效果好。

缺点:

最坏情况下的时间复杂度为O(n^2):当输入数组已经近乎有序或完全逆序时,分割过程可能导致递归树不平衡。

不稳定排序:相等元素的顺序可能会改变。

实现原理:

快速排序的基本步骤包括选择一个基准值(通常是第一个或最后一个元素),然后通过一趟分区操作将数组分为两个部分,左边的部分都小于基准,右边的部分都大于或等于基准。接着递归地对左右两部分进行同样的操作,直到所有子序列有序。

实际应用:

由于快速排序的速度快,它常用于需要大量数据排序的各种场景,比如数据库、搜索引擎的数据处理,以及编程语言的标准库中。

Python实现:

c 复制代码
Python
def quicksort(arr):
    if len(arr) <= 1:
        return arr
    pivot = arr[len(arr) // 2]
    less = [x for x in arr if x < pivot]
    equal = [x for x in arr if x == pivot]
    greater = [x for x in arr if x > pivot]
    return quicksort(less) + equal + quicksort(greater)

# 测试
arr = [3,6,8,10,1,2,1]
sorted_arr = quicksort(arr)
print("Sorted array:", sorted_arr)
相关推荐
寒秋花开曾相惜1 小时前
(学习笔记)第四章 处理器体系结构
linux·网络·数据结构·笔记·学习
故事和你911 小时前
洛谷-数据结构1-1-线性表1
开发语言·数据结构·c++·算法·leetcode·动态规划·图论
脱氧核糖核酸__1 小时前
LeetCode热题100——53.最大子数组和(题解+答案+要点)
数据结构·c++·算法·leetcode
脱氧核糖核酸__2 小时前
LeetCode 热题100——42.接雨水(题目+题解+答案)
数据结构·c++·算法·leetcode
王老师青少年编程3 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:数列分段 Section I
c++·算法·编程·贪心·csp·信奥赛·线性扫描贪心
王老师青少年编程3 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:分糖果
c++·算法·贪心算法·csp·信奥赛·线性扫描贪心·分糖果
_日拱一卒3 小时前
LeetCode:2两数相加
算法·leetcode·职场和发展
py有趣3 小时前
力扣热门100题之零钱兑换
算法·leetcode
董董灿是个攻城狮3 小时前
Opus 4.7 来了,我并不建议你升级
算法
自我意识的多元宇宙3 小时前
二叉树遍历方式代码解读(2迭代)
数据结构