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

一、基本思想

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

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

例如下图:

二、实例:

(1)int a[5] = {5,3,6,9,2,4};

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

(2)int a[5] = {3,5,6,9,2,4};

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

(3)int a[5] = {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循环后赋值
	}
}

//加油加油!

相关推荐
月挽清风几秒前
代码随想录第35天:动态规划
算法·动态规划
岛雨QA8 分钟前
链表「Java数据结构与算法学习笔记3」
数据结构·算法
Sunsets_Red15 分钟前
P8277 [USACO22OPEN] Up Down Subsequence P 题解
c语言·c++·算法·c#·学习方法·洛谷·信息学竞赛
菜鸟小九17 分钟前
redis原理篇(基本数据结构)
数据结构·数据库·redis
汉克老师24 分钟前
GESP2023年12月认证C++二级( 第三部分编程题(2) 小杨的H字矩阵)
c++·算法·矩阵·循环结构·gesp二级·gesp2级
_Li.26 分钟前
Simulink-螺旋桨动力模块
人工智能·算法·机器学习
Charlie_lll28 分钟前
力扣解题-438. 找到字符串中所有字母异位词
后端·算法·leetcode
奶茶树30 分钟前
【数据结构】红黑树
数据结构·c++·算法
AI周红伟32 分钟前
周红伟:OpenAI 首席运营官,尚未真正看到人工智能渗透到企业业务流程中
人工智能·算法·性能优化
问好眼34 分钟前
《算法竞赛进阶指南》0x01 位运算-2.增加模数
c++·算法·位运算·信息学奥赛