Bootstrap

排序速记

冒泡排序:(稳定)

1.   比较相邻的元素。如果第一个比第二个大,就交换他们两个。

2.   对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。这步做完后,最后的元素会是最大的数。

3.   针对所有的元素重复以上的步骤,除了最后一个。

4.    持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。

选择排序:

1.   首先,找到数组中最小的那个元素,

2.   其次,将它和数组的第一个元素交换位置(如果第一个元素就是最小元素那么它就和自己交换)。

3.   再次,在剩下的元素中找到最小的元素,将它与数组的第二个元素交换位置。

4.    如此往复、直到将整个数组排序.这种方法叫做选择排序,因为它在不断地选择剩余元素之中的最小者。

不稳定:举个例子,序列5 8 52 9, 我们知道第一遍选择第1个元素5会和2交换,那么原序列中2个5的相对前后顺序就被破坏了,所以选择排序不是一个稳定的排序算法

插入排序:(稳定)

从第个位置的元素开始,若相邻元素,则交换;否则进行第个位置的元素的插入排序;适用于前期较有序的序列

Shell排序:(不稳定)

相对于插入排序相邻变为相差:从第个位置的元素开始,若,则交换;否则进行第个位置的元素的插入排序;排完当前后,,继续排序。(到最后都会回归到(插入排序),但是前期的排序为插入排序提供了良好的基础)

归并排序:

基本思想: 嵌套循环

自顶向下:尺寸由大到小切割排序,再合并;

自底向上:尺寸小到大排序,再合并;

 

快速排序:

选择一个元素将所有大于该元素的元素放在右边,所有小于该元素的元素放到左边;再对左序列和右序列分别进行快速排序,直到子序列的长度为1。

 

堆排序:

基于二叉树,每次排序成大顶堆二叉树(每个结点的值都大于或等于其左右孩子结点的值),最后一个叶节点的值为最小值,一次排序直到依次找出所有排序过程中的最小值。


图片来源:

https://baike.baidu.com/pic/%E6%97%B6%E9%97%B4%E5%A4%8D%E6%9D%82%E5%BA%A6/1894057/0/b999a9014c086e06b5dc7f6d00087bf40ad1cba4?fr=lemma&ct=single#aid=0&pic=b999a9014c086e06b5dc7f6d00087bf40ad1cba4

;