排序算法——直接插入排序

直接插入排序与希尔排序是插入排序的两个分支,直接插入排序是较为简单的一种排序算法,同时也是众多算法实现或优化的基石。

前提:

插入排序:有一个已经有序的数据序列,要求在这个已经排好的数据序列中插入一个数,但要求插入后此数据序列仍然有序, 这个时候就要用到一种新的排序方法--插入排序法,插入排序的基本操作就是将一个数据插入到已经排好序的有序数据中,从而得到一个新的、个数加一的有序数据,算法适用于少量数据的排序,是稳定的排序方法。

简单来说,就是打斗地主时,你已经摸了几张牌并将牌从小到大排列成有序的概况,这时再摸一张牌,将其也插入到合适的位置,使所有牌继续有序。

算法思想分析:

直接插入排序自然秉承了这一思想,直接插入排序算法的思想是:当插入第i个元素时,arr[0]到arr[i-1]个元素已经排好序,这时用array[i]按与array[i-1],array[i-2],...的顺序依次进行比较,如果找到合适的位置就将arr[i]插入,没找到就继续比较,原来位置的元素顺序后移。

有图有真相:


举个例子:

arr[i]=27,在arr[i]前面的数字已经有序,这时就将arr[i]与arr[i-1]ye也就是27与47比较。

27小,47向后移。

arr[i]再与arr[i-2]也就是44比

,27小,44向后移.......

与arr[i-4](即36)比较,36小,36向后移。

直到遇到arr[i-5]也就是26,27比26大。27插入到原arr[i-4]的位置,单趟排序结束。

代码如下:

这里我们定义一个变量end,假设从a[0]到a[end]范围有序,定义tmp保存下标为第end+1的数。

while循环,如果tmp比它前一个数小,前一个数后移,tmp继续比较。直到遇到比tmp小的或者tmp最小(end=-1,tmp应落到arr[0]位置),循环结束。将tmp赋给end+1的位置,保持有序。

上面这段代码目的是将第i个数插入到合适的位置,也就是说这是一个单趟排序。;了解了单趟排序,将一堆杂乱的数排序成有序序列(多趟排序)就很简单了:

我们在while循环外再套一层for循环,当i=0时,只有一个数据,是有序的。

i=1时,两个数据:进行比较.......

最后当end=n-2时(倒数第二个元素),与最后一个数比较,整个数组有序。

检验:

最后的打印函数一并在这。

时间复杂度:O(n^2)

最坏情况全部杂乱,需要单趟排序一次一次重复比较,铁铁的O(n^2);

最好情况就是全部有序,此时只需遍历一次,这时时间复杂度为O(n);

空间复杂度:O(1)

它是一种稳定的排序算法

相关推荐
郝学胜-神的一滴34 分钟前
Leetcode 969 煎饼排序✨:翻转间的数组排序艺术
数据结构·c++·算法·leetcode·面试
I_LPL8 小时前
hot100贪心专题
数据结构·算法·leetcode·贪心
颜酱8 小时前
DFS 岛屿系列题全解析
javascript·后端·算法
WolfGang0073219 小时前
代码随想录算法训练营 Day16 | 二叉树 part06
算法
2401_8318249610 小时前
代码性能剖析工具
开发语言·c++·算法
Sunshine for you11 小时前
C++中的职责链模式实战
开发语言·c++·算法
qq_4160187211 小时前
C++中的状态模式
开发语言·c++·算法
2401_8845632411 小时前
模板代码生成工具
开发语言·c++·算法
2401_8319207411 小时前
C++代码国际化支持
开发语言·c++·算法
m0_6727033111 小时前
上机练习第51天
数据结构·c++·算法