您的位置:首页 >Python常见排序算法有哪些?
发布于2026-04-21 阅读(0)
扫一扫,手机访问
冒泡排序时间复杂度O(n²),空间复杂度O(1),稳定;选择排序O(n²),O(1),不稳定;插入排序平均O(n²),最好O(n),稳定;快速排序平均O(n log n),空间O(log n),不稳定;归并排序始终O(n log n),空间O(n),稳定;堆排序O(n log n),空间O(1),不稳定;Timsort结合归并与插入,最好O(n),稳定,为Python默认排序算法。

Python中常见的排序算法有很多,虽然日常开发中我们通常使用内置的sort()或sorted()函数,但了解底层的常见排序算法有助于理解性能差异和应对面试。以下是几种经典的排序算法:
冒泡排序通过重复遍历列表,比较相邻元素并交换位置,将最大值“冒泡”到末尾。
特点:适合教学理解,实际应用较少。
每次从未排序部分选出最小元素,放到已排序部分的末尾。
特点:比冒泡略高效,但仍不适用于大数组。
将未排序元素逐个插入到已排序部分的正确位置,类似整理扑克牌。
特点:小数据或基本有序的数据表现不错,是某些高级算法的子过程(如Timsort中用到)。
采用分治法,选一个基准(pivot),将小于和大于基准的元素分区,递归排序两部分。
特点:实践中非常高效,Python的list.sort()早期版本曾基于快排(现为Timsort)。
也是分治法,将数组不断二分,直到单个元素,再合并有序子数组。
特点:适合对稳定性有要求的场景,也是Timsort的基础之一。
利用堆这种数据结构(通常是最大堆)进行排序,反复提取堆顶元素。
特点:性能稳定,但常数较大,实际中不如快排或归并常用。
Python内置排序使用的是Timsort,由Tim Peters在2002年为Python设计。
特点:现代Python中list.sort()和sorted()都使用Timsort,是工业级实现的典范。
基本上就这些。学习基础算法能帮助你写出更高效的代码,也能更好理解工具背后的原理。
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9