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

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

前提:

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

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

算法思想分析:

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

它是一种稳定的排序算法

相关推荐
DuHz6 小时前
论文精读:大语言模型 (Large Language Models, LLM) —— 一项调查
论文阅读·人工智能·深度学习·算法·机器学习·计算机视觉·语言模型
加农炮手Jinx6 小时前
LeetCode 72. Edit Distance 题解
算法·leetcode·力扣
借雨醉东风6 小时前
程序分享--常见算法/编程面试题:旋转矩阵
c++·线性代数·算法·面试·职场和发展·矩阵
_深海凉_6 小时前
LeetCode热题100-打家劫舍
算法·leetcode·职场和发展
jghhh017 小时前
使用 MATLAB 实现支持向量回归 (SVR) 预测未来数据
算法·matlab
云泽8087 小时前
笔试算法 - 双指针篇(二):四大经典求和题型 + 有效三角形计数问题
c++·算法
qeen878 小时前
【数据结构】树的基本概念及存储
c语言·数据结构·c++·学习·
一江寒逸8 小时前
数据结构与算法之美:串(字符串)——从基础操作到KMP模式匹配,吃透面试最高频的字符串考点
数据结构·面试·职场和发展
刀法如飞9 小时前
【合并已排序数组的三种实现策略,哪一种更可取?】
算法·程序员
王老师青少年编程9 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【区间贪心】:种树
c++·算法·贪心·csp·信奥赛·区间贪心·种树