快速排序算法

快速排序算法

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

优点:

时间效率高:平均时间复杂度为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)
相关推荐
蹉跎x27 分钟前
力扣1358. 包含所有三种字符的子字符串数目
数据结构·算法·leetcode·职场和发展
坊钰1 小时前
【Java 数据结构】移除链表元素
java·开发语言·数据结构·学习·链表
巫师不要去魔法部乱说2 小时前
PyCharm专项训练4 最小生成树算法
算法·pycharm
IT猿手2 小时前
最新高性能多目标优化算法:多目标麋鹿优化算法(MOEHO)求解GLSMOP1-GLSMOP9及工程应用---盘式制动器设计,提供完整MATLAB代码
开发语言·算法·机器学习·matlab·强化学习
阿七想学习2 小时前
数据结构《排序》
java·数据结构·学习·算法·排序算法
王老师青少年编程2 小时前
gesp(二级)(12)洛谷:B3955:[GESP202403 二级] 小杨的日字矩阵
c++·算法·矩阵·gesp·csp·信奥赛
Kenneth風车3 小时前
【机器学习(九)】分类和回归任务-多层感知机(Multilayer Perceptron,MLP)算法-Sentosa_DSML社区版 (1)111
算法·机器学习·分类
越甲八千3 小时前
总结一下数据结构 树 的种类
数据结构
eternal__day3 小时前
数据结构(哈希表(中)纯概念版)
java·数据结构·算法·哈希算法·推荐算法
APP 肖提莫3 小时前
MyBatis-Plus分页拦截器,源码的重构(重构total总数的计算逻辑)
java·前端·算法