常用的排序算法
常用的排序算法
如何分析一个“排序算法”?
排序算法的执行效率
- 最好情况、最坏情况、平均情况时间复杂度
- 时间复杂度的系数、常数 、低阶
在对同一阶时间复杂度的排序算法性能对比的时候,我们就要把系数、常数、低阶也考虑进来。 - 比较次数和交换(或移动)次数
基于比较的排序算法
的执行过程,会涉及两种操作,一种是元素比较大小,另一种是元素交换或移动。所以,如果我们在分析排序算法的执行效率的时候,应该把比较次数和交换(或移动)次数也考虑进去。
排序算法的内存消耗
针对排序算法的空间复杂度,我们还引入了一个新的概念,原地排序(Sorted in place)
。原地排序算法,就是特指空间复杂度是 O(1) 的排序算法。冒泡、插入、选择排序,都是原地排序算法。
排序算法的稳定性
针对排序算法,我们还有一个重要的度量指标,稳定性
。这个概念是说,如果待排序的序列中存在值相等的元素,经过排序之后,相等元素之间原有的先后顺序不变。
经过某种排序算法之后,原先相等的两个元素前后顺序没有改变,我们就把这种排序算法叫作稳定的排序算法
;反之,叫作不稳定的排序算法
。
1. 冒泡排序(Bubble Sort)
冒泡排序只会操作相邻的两个数据。每次冒泡操作都会对相邻的两个元素进行比较,看是否满足大小关系要求。如果不满足就让它俩互换。一次冒泡会让至少一个元素移动到它应该在的位置,重复 n 次,就完成了 n 个数据的排序工作。
冒泡排序
2. 插入排序
首先,我们将数组中的数据分为两个区间,已排序区间和未排序区间。初始已排序区间只有一个元素,就是数组的第一个元素。插入算法的核心思想是取未排序区间中的元素,在已排序区间中找到合适的插入位置将其插入,并保证已排序区间数据一直有序。重复这个过程,直到未排序区间中元素为空,算法结束。
3. 选择排序
选择排序算法的实现思路有点类似插入排序,也分已排序区间和未排序区间。但是选择排序每次会从未排序区间中找到最小的元素,将其放到已排序区间的末尾。
选择排序
冒泡、插入、选择排序
算法过程动态图,可以看看这个https://visualgo.net/
网友评论