算法系列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 小时前
二分搜索-C
c语言·算法
智者知已应修善业1 小时前
【查找指定字符串首位置与数量不区分大小写完整匹配】2025-5-3
c语言·c++·经验分享·笔记·算法
fengfuyao9851 小时前
基于局部均值分解(LMD)的MATLAB信号分解程序实现
算法·matlab·均值算法
㓗冽1 小时前
分割数字并排序(字符串)-基础题103th + A == B ?(字符串)-基础题104th + 母牛制造的回文(字符串)-基础题105th
算法
Ronin3051 小时前
信道管理模块和异步线程模块
开发语言·c++·rabbitmq·异步线程·信道管理
yoyo君~1 小时前
从内存管理到并发架构:C++ 核心内功修炼指南
开发语言·c++·学习·无人机
问好眼2 小时前
《算法竞赛进阶指南》0x01 位运算-4.最短Hamilton路径
c++·算法·动态规划·位运算·信息学奥赛
苦藤新鸡2 小时前
65.搜索平移数组的最小值
算法·leetcode
载数而行5202 小时前
算法系列5之交换排序
c语言·数据结构·c++·算法·排序算法