排序:
所谓排序,就是使一串记录,按照其中的某个或某些关键字的大小,递增或递减的排列起来的操作。
常见排序法
**.**常见排序算法的实现
插入排序
1.直接插入排序
2.希尔排序**(**缩小增量排序)
希尔排序的特性总结:
- 希尔排序是对直接插入排序的优化。
- 当 gap > 1 时都是预排序,目的是让数组更接近于有序。当 gap == 1 时,数组已经接近有序的了,这样就会很 快。这样整体而言,可以达到优化的效果。
- 希尔排序的时间复杂度不好计算,因为 gap 的取值方法很多,导致很难去计算,因此在好些树中给出的希尔排 序的时间复杂度都不固定
选择排序
直接选择排序**:**
在元素集合 array[i]--array[n-1] 中选择关键码最大 ( 小 ) 的数据元素
若它不是这组元素中的最后一个 ( 第一个 ) 元素,则将它与这组元素中的最后一个(第一个)元素交换 在剩余的array[i]--array[n-2] ( array[i+1]--array[n-1] )集合中,重复上述步骤,直到集合剩余 1 个元素
【 直接选择排序的特性总结 】
- 直接选择排序思考非常好理解,但是效率不是很好。实际中很少使用
- 时间复杂度: O(N^2)
- 空间复杂度: O(1)
- 稳定性:不稳定
堆排序
堆排序 (Heapsort) 是指利用堆积树(堆)这种数据结构所设计的一种排序算法,它是选择排序的一种。它是通过堆 来进行选择数据。需要注意的是排升序要建大堆,排降序建小堆。
【 直接选择排序的特性总结 】
- 堆排序使用堆来选数,效率就高了很多。
- 时间复杂度: O(N*logN)
- 空间复杂度: O(1)
- 稳定性:不稳定
交换排序
1****冒泡排序
【冒泡排序的特性总结】
- 冒泡排序是一种非常容易理解的排序
- 时间复杂度: O(N^2)
- 空间复杂度: O(1)
- 稳定性:稳定
2.快速排序
. Hoare****版
挖坑法(优先考虑)
前后指针
快速排序优化
快速排序递归
快速排序非递归
2.3.4 快速排序总结
- 快速排序整体的综合性能和使用场景都是比较好的,所以才敢叫 快速 排序
- 时间复杂度: O(N*logN)
- 空间复杂度: O(logN)
- 稳定性:不稳定
归并排序
归并排序总结
-
归并的缺点在于需要 O(N) 的空间复杂度,归并排序的思考更多的是解决在磁盘中的外排序问题。
-
时间复杂度: O(N*logN)
-
空间复杂度: O(N)
-
稳定性:稳定
记数排序
【计数排序的特性总结】
- 计数排序在数据范围集中时,效率很高,但是适用范围及场景有限。
- 时间复杂度: O(MAX(N, 范围 ))
- 空间复杂度: O( 范围 )
- 稳定性:稳定