插入排序详解

思路

把后面的值(temp)与前面的值(end)做对比,

若temp位置的值小于end位置的值,

end位置的值给end+1位置。。

语言难以描述,请大家看下图。

代码

cpp 复制代码
void InsertSort(int *arr, int n)
{
	/*为了防止数组越界,我们最多访问到n-2就停止,
因为此时temp会赋值到n-1(数组的最后一个元素),
所以i<n-1即可*/
	for (int i = 0; i < n - 1; i++)
	{
		int end = i;
		int temp = arr[end + 1];

//注意是end>=0而不是end>0,因为下标为0与下标为1的值也需要比较
		while (end >= 0)
		{
			if (temp < arr[end])
			{
				arr[end + 1] = arr[end];
//end下标往数组前面走,继续下一次对比
				end--;
			}
//没有比temp大的值就终止本次循环
			else
			{
				break;
			}
		}
//前面没有比temp更小的值了,空出来的位置是end+1,temp的值就到这里来
		arr[end + 1] = temp;
	}
}
相关推荐
槐月杰2 小时前
C语言中冒泡排序和快速排序的区别
c语言·算法·排序算法
奋进的小暄3 小时前
数据结构(java)栈与队列
java·开发语言·数据结构
笺上山河梦4 小时前
文件操作(二进制文件)
开发语言·c++·学习·算法
大慕慕好懒4 小时前
PHP弱类型hash比较缺陷
算法·哈希算法
snowfoootball5 小时前
最短路问题
数据结构·算法
怀旧,6 小时前
【数据结构】4.单链表实现通讯录
android·服务器·数据结构
有你的冬天1986 小时前
数据结构(一)
数据结构·算法
虾球xz6 小时前
游戏引擎学习第221天:(实现多层次过场动画)
c++·学习·游戏引擎
满怀10156 小时前
【Python进阶】列表:全面解析与实战指南
python·算法
purrrew6 小时前
【数据结构_9】栈和队列
数据结构