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

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

前提:

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

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

算法思想分析:

直接插入排序自然秉承了这一思想,直接插入排序算法的思想是:当插入第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)

它是一种稳定的排序算法

相关推荐
舟舟亢亢5 小时前
算法总结——二叉树【hot100】(上)
java·开发语言·算法
weixin_477271696 小时前
根象:树根。基石。基于马王堆帛书《周易》原文及甲骨文还原周朝生活活动现象(《函谷门》原创)
算法·图搜索算法
普通网友7 小时前
多协议网络库设计
开发语言·c++·算法
努力努力再努力wz7 小时前
【Linux网络系列】:TCP 的秩序与策略:揭秘传输层如何从不可靠的网络中构建绝对可靠的通信信道
java·linux·开发语言·数据结构·c++·python·算法
daxi1507 小时前
C语言从入门到进阶——第9讲:函数递归
c语言·开发语言·c++·算法·蓝桥杯
持续学习的程序员+18 小时前
强化学习Q-chunking算法
算法
Polaris北8 小时前
第二十七天打卡
开发语言·c++·算法
风吹乱了我的头发~9 小时前
Day30:2026年2月20日打卡
算法
blackicexs9 小时前
第五周第五天
算法
不吃橘子的橘猫9 小时前
《集成电路设计》复习资料2(设计基础与方法)
学习·算法·fpga开发·集成电路·仿真·半导体