商城首页欢迎来到中国正版软件门户

您的位置:首页 >Python常见排序算法有哪些?

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常见的排序算法有哪些?

Python中常见的排序算法有很多,虽然日常开发中我们通常使用内置的sort()sorted()函数,但了解底层的常见排序算法有助于理解性能差异和应对面试。以下是几种经典的排序算法:

1. 冒泡排序(Bubble Sort)

冒泡排序通过重复遍历列表,比较相邻元素并交换位置,将最大值“冒泡”到末尾。

特点:
  • 时间复杂度:O(n²),不适合大数据量
  • 空间复杂度:O(1),原地排序
  • 稳定排序

适合教学理解,实际应用较少。

2. 选择排序(Selection Sort)

每次从未排序部分选出最小元素,放到已排序部分的末尾。

特点:
  • 时间复杂度:O(n²)
  • 空间复杂度:O(1)
  • 不稳定排序(相同元素可能改变相对位置)

比冒泡略高效,但仍不适用于大数组。

3. 插入排序(Insertion Sort)

将未排序元素逐个插入到已排序部分的正确位置,类似整理扑克牌。

特点:
  • 时间复杂度:平均/最坏 O(n²),最好 O(n)(接近有序时)
  • 空间复杂度:O(1)
  • 稳定排序

小数据或基本有序的数据表现不错,是某些高级算法的子过程(如Timsort中用到)。

4. 快速排序(Quick Sort)

采用分治法,选一个基准(pivot),将小于和大于基准的元素分区,递归排序两部分。

特点:
  • 时间复杂度:平均 O(n log n),最坏 O(n²)
  • 空间复杂度:O(log n)(递归栈)
  • 不稳定排序

实践中非常高效,Python的list.sort()早期版本曾基于快排(现为Timsort)。

5. 归并排序(Merge Sort)

也是分治法,将数组不断二分,直到单个元素,再合并有序子数组。

特点:
  • 时间复杂度:始终 O(n log n)
  • 空间复杂度:O(n),需要额外存储
  • 稳定排序

适合对稳定性有要求的场景,也是Timsort的基础之一。

6. 堆排序(Heap Sort)

利用堆这种数据结构(通常是最大堆)进行排序,反复提取堆顶元素。

特点:
  • 时间复杂度:O(n log n)
  • 空间复杂度:O(1)
  • 不稳定排序

性能稳定,但常数较大,实际中不如快排或归并常用。

7. Timsort(Python默认使用的算法)

Python内置排序使用的是Timsort,由Tim Peters在2002年为Python设计。

特点:
  • 结合了归并排序和插入排序的优点
  • 对真实世界数据(如部分有序)特别高效
  • 时间复杂度:最好 O(n),平均/最坏 O(n log n)
  • 稳定排序

现代Python中list.sort()sorted()都使用Timsort,是工业级实现的典范。

基本上就这些。学习基础算法能帮助你写出更高效的代码,也能更好理解工具背后的原理。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。

热门关注