算法系列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

相关推荐
Old Uncle Tom1 天前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
会编程的土豆1 天前
洛谷题单入门1 顺序结构
数据结构·算法·golang
生信碱移1 天前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
智者知已应修善业1 天前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
智者知已应修善业1 天前
【51单片机按键调节占空比3位数码管显示】2023-8-24
c++·经验分享·笔记·算法·51单片机
JasmineX-11 天前
数据结构(笔记)——双向链表
c语言·数据结构·笔记·链表
.5481 天前
## Sorting(排序算法)
python·算法·排序算法
wuweijianlove1 天前
算法的平均复杂度建模与性能回归分析的技术7
算法·数据挖掘·回归
子琦啊1 天前
【算法复习】字符串 | 两个底层直觉,吃透高频题
linux·运维·算法