算法系列4之插入排序

一.插入排序

1.排序介绍

1.就地排序

不需要辅助空间

例子

2.非就地排序

需要辅助空间来装排好序的一组数

3.稳定及非稳定排序

稳定排序

两个关键字相等的元素,排序后相对位置不变

​非稳定排序

两个关键字相等的元素,排序后相对位置可能被打乱

例子

冒泡,插入,归并,计数...是稳定的

快排和堆排序是非稳定的:利用空间换时间的方法来变得稳定

2.插入排序

1.三大思想

(1)元素后移+最后插入(分成有序表和无序表)

(2)扑克牌思想:一步一交换

(3)希尔排序:按照步长交换(在利用1 2的某种思想)

2.插入排序

分成有序表和无序表,开始时有序表有1个元素,无序表有n-1个元素,重复n-1排好顺序

3.希尔排序

对比之前的优化:避免在即将拍好序之后突然出现一个极小的数,会造成有序区移动时间过长;可以先按照较小的步长依次排序,然后步长在依次增大

插入排序优点

数量小,插入排序优势大

二.插入代码

.h

.c

main.c

三.排序底层通用代码

.h

.c

相关推荐
四代水门1 分钟前
LeetCode刷算法题(C++)
c++·算法·leetcode
一头老黄牛@3 分钟前
飞书 × OpenClaw 接入指南:不用服务器,用长连接把机器人跑起来
数据结构·人工智能·程序人生·算法·决策树·自动化·推荐算法
Passionate.Z10 分钟前
基于FPGA的CLAHE自适应限制对比度直方图均衡算法硬件verilog实现
图像处理·嵌入式硬件·算法·fpga开发·fpga
Zhan8611242 小时前
数据接口的序列号机制与丢包检测:西班牙行情数据IBEX指数实时行情接入笔记
大数据·数据结构·笔记·区块链
菜鸡爱玩4 小时前
线性代数矩阵相乘
线性代数·算法·矩阵
devilnumber8 小时前
Java 递归算法 详解 + 核心要点 + 实战运用 + 避坑指南
java·开发语言·算法
unicrom_深圳市由你创科技9 小时前
哪些控制逻辑应该放在 PLC,哪些放在上位机?
c++
‎ദ്ദിᵔ.˛.ᵔ₎10 小时前
双指针、滑动窗口、前缀和、二分查找 算法
算法
顾北顾10 小时前
多头注意力机制
人工智能·深度学习·算法
H1785350909610 小时前
SolidWorks_基于草图的实体特征20_特征错误排查
算法·3d建模·solidworks