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

相关推荐
郭涤生7 小时前
飞凌 RK3588 开发板同显 / 异显模式切换
c++·rk3588
计算机安禾7 小时前
【c++面向对象编程】第38篇:设计原则(二):里氏替换、接口隔离与依赖倒置
开发语言·c++
ʚ希希ɞ ྀ8 小时前
单词拆分----dp
算法
code_whiter8 小时前
C++1进阶(继承)
开发语言·c++
智者知已应修善业8 小时前
【51单片机LED闪烁10次数码管显示0-9】2023-12-14
c++·经验分享·笔记·算法·51单片机
智者知已应修善业8 小时前
【51单片机2按键控制1个敞亮LED灯闪烁和熄灭】2023-11-3
c++·经验分享·笔记·算法·51单片机
AI算法沐枫8 小时前
大模型 | 大模型之机器学习基本理论
人工智能·python·神经网络·学习·算法·机器学习·计算机视觉
吃着火锅x唱着歌9 小时前
LeetCode 1019.链表中的下一个更大节点
算法·leetcode·链表
咩咦9 小时前
C++学习笔记20:日期类比较运算符重载
c++·学习笔记·类和对象·运算符重载·比较运算符·日期类