【实现常见排序算法】直接插入排序的算法思想

一、基本思想

把待排序的数值按其关键码值的大小逐个插入到一个已经排好序的有序序列中,直到所有的待排序的数值插入完为止,最后会得到一个新的有序序列。

这个过程与我们玩扑克牌发牌时对牌面的排序有异曲同工之妙。起初,我们只有一张牌,此时,这张牌的牌面就是我们手中最小的,随着第二轮发牌,我们将第二张牌面大小与第一张比较,大的话插在后面,小的话放在后面...以此类推。

例如下图:

二、实例:

(1)int a5 = {5,3,6,9,2,4};

end指向有序数列的最后一个位置(end=i(==0))。同时要注意,交换前要将aend+1进行备份tmp,以免被覆盖后找不到数值。假设当前有序数列为5,现在end指向5这个位置,end+1指向3这个位置,判断aend>tmp(3); 如果结果为true,end--,其中,挪数据同样需要一个循环,这样的话内层循环t条件就可以设定为end>=0,此时end<0,end+1==0,越界退出,将tmp赋值给aend+1,且i++。

(2)int a5 = {3,5,6,9,2,4};

end此时等于1,将end所指值与tmp比较,判断aend>tmp; 如果为true,end--,向前挪动数据,此时end=0,继续判断,以此类推,end--,此时end<0,越界退出,i++。

(3)int a5 = {3,5,6,9,2,4};

end此时等于2,......

如下是AI对于上述我的语言进行的总结2333:

插入排序的关键操作说明:

有序数列的边界处理

  • 变量end始终指向当前有序部分的最后一个元素位置。例如初始时end=0(假设数组第一个元素已有序),此时end+1指向待插入元素的位置。
  • 在插入前需将a[end+1]的值备份到tmp,避免后续移动元素时被覆盖。

元素移动与插入逻辑

  • 比较阶段:若a[end] > tmp(待插入值),则将a[end]向后移动一位,并通过end--向前检查有序部分的其他元素。
  • 终止条件:移动循环需满足end >= 0。当end减至-1时,说明tmp应插入数组首位,此时end+10,不会越界。
  • 插入操作:退出循环后将tmp赋值给a[end+1],完成插入。随后i++进入下一轮排序。

示例流程 有序数列为[5],待插入值为3

  1. end=0tmp=3(备份a[1]
  2. 比较5 > 3,移动5a[1]end变为-1
  3. 循环终止,将3插入a[0](因end+1=0
  4. 更新后的数列为[3,5],进入下一轮迭代

三、代码实现:

cpp 复制代码
void InserSort(int* arr, int n)
{
	for(int i=0;i<n-1;i++)
//end可以等于n吗?不可以,因为等于n时,end指向有序数组中的最后一个数据,
//指向n时说明已经没有待插入数据了,且此时end+1越界,故end最大等于n-1

	{
		int end = i;
		int tmp = arr[end + 1];
		while (end >= 0)
		{
			if (arr[end] > tmp)
			{
				arr[end+1] = arr[end];
				end--;
			}
			else {
				break;
			}	
		}
		arr[end+1] = tmp;//前面一直在判断,跳出while循环后赋值
	}
}

//加油加油!

相关推荐
To_OC7 小时前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode
金銀銅鐵10 小时前
[Python] 扩展欧几里得算法
python·数学·算法
To_OC13 小时前
LC 200 岛屿数量:经典 DFS 入门题,我第一次写居然连方向都搞错了
javascript·算法·leetcode
To_OC1 天前
LC 128 最长连续序列:别上来就排序,O (n) 解法才是这题的灵魂
javascript·算法·leetcode
刘马想放假2 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
05Kevin2 天前
lk每日冒险题--数据结构6.27
算法
To_OC2 天前
从一次栈溢出报错说起,我把递归彻底扒明白了
javascript·算法·程序员
千纸鹤安安2 天前
千问Qwen-AgentWorld来了:一个语言模型搞定七大Agent场景,GPT-5.4都输了
算法