时间复杂度为 O(n^2) 的排序算法

💡 原文中文,约2800字,阅读约需7分钟。
📝

内容提要

对于小规模数据,O(n²) 排序算法可能更高效。插入排序适合部分有序数组,希尔排序通过交换不相邻元素提高效率。选择排序每次选最小值放到已排序区末尾,冒泡排序通过比较和交换相邻元素排序。插入排序和冒泡排序是稳定的,选择排序不稳定。希尔排序适合大规模数组,插入排序在小数据量时表现优异。

🎯

关键要点

  • 对于小规模数据,O(n²) 排序算法可能更高效。
  • 时间复杂度并不代表实际代码的执行时间,O(n²) 算法在小规模数据时可能比 O(nlogn) 更快。
  • 稳定性:排序后等值元素相对位置不变为稳定排序,反之为不稳定排序。
  • 插入排序适合部分有序数组,效率高。
  • 插入排序的空间复杂度为 O(1),是原地排序且稳定。
  • 希尔排序通过交换不相邻元素提高效率,适合大规模数组。
  • 选择排序每次选择未排序数组中的最小值放到已排序区末尾,空间复杂度为 O(1),是原地排序但不稳定。
  • 冒泡排序通过比较和交换相邻元素实现排序,空间复杂度为 O(1),是原地排序且稳定。

延伸问答

O(n²) 排序算法适合什么样的数据规模?

O(n²) 排序算法适合小规模数据,可能比 O(nlogn) 更高效。

插入排序的空间复杂度是多少?

插入排序的空间复杂度为 O(1),是原地排序且稳定。

希尔排序是如何提高排序效率的?

希尔排序通过交换不相邻的元素对数组的局部进行排序,从而提高效率。

选择排序的稳定性如何?

选择排序是不稳定的,会改变等值元素之间的相对位置。

冒泡排序的最佳时间复杂度是多少?

经过优化后的冒泡排序最佳时间复杂度为 O(n)。

在什么情况下插入排序表现优异?

插入排序在部分有序数组或数据量较小的情况下表现优异。

➡️

继续阅读