-
直接插入排序
①所给元素越接近有序,直接插入排序的时间效率越高
②时间复杂度: O(N^2)
③空间复杂度: O(1)
④稳定性: 稳定
-
希尔排序
①希尔排序是对直接插入排序的优化
②当gap > 1时,都是预排序,目的是让数组更接近于有序; 当gap == 1时,数组已经接近有序的了,这样就会很快。这样整体 而言,可以达到优化的效果
③时间复杂度:希尔排序的时间复杂度不好计算,需要进行推导,推导出来平均时间复杂度: O(N^1.3 -N^2)
④空间复杂度:O(1)
⑤稳定性: 不稳定
-
直接选择排序
①直接选择排序好理解,但是效率不是很好。实际中很少使用
②时间复杂度: O(N^2)
③空间复杂度: O(1)
④稳定性:不稳定(可以调整为稳定的)
-
堆排序
①堆排序使用堆来选数,效率就高了很多
②时间复杂度: O(N*logN)
③空间复杂度: O(1)
④稳定性:不稳定
-
冒泡排序
①冒泡排序是一种非常容易理解的排序
②时间复杂度: O(N^2)
③空间复杂度: O(1)
④稳定性:稳定
-
快速排序
①快速排序整体的综合性能和使用场景都是比较好的,所以才敢叫快速排序
②时间复杂度: O(N*logN)
③空间复杂度: O(logN)
④稳定性:不稳定
-
归并排序
①归并的缺点在于需要O(N)的空间复杂度,归并排序的思考更多的是解决在磁盘中的外排序问题
②时间复杂度: O(N*logN)
③空间复杂度: O(N)
④稳定性:稳定
-
计数排序
①计数排序在数据范围集中时,效率很高,但是适用范围及场景有限
②时间复杂度: O(MAX(N,范围))
③空间复杂度: O(范围)
④稳定性:稳定
-
数据敏感性
数据敏感类型:冒泡排序、快速排序、直接插入排序、希尔排序
数据不敏感类型:直接选择排序、堆排序、归并排序、计数排序
- 注意:
稳定性:所谓稳定性是指待排序的序列中有两元素相等,排序之后它们的先后顺序不变。
数据敏感:数据敏感是指给定数据无序和有序,对排序的效率影响很大。