插入排序(C语言)

直接插入排序的基本思想:把待排序的记录按其关键码值的大小逐个插入到一个已经排好序的有序序列中,直到所有的记录插入完为止,得到一个新的有序序列 。

一、步骤

1.给定一个乱序的数组,如

从第一个元素开始排序,当只有第一个元素4时,我们可以认为它是有序的。

2.然后取出下一个元素,在这里是第二个元素即5,将这个元素赋值变量tmp,然后进行插入

3.如果前一个元素大于tmp,则该元素向后移,重复上述步骤,直到找到小于tmp的位置

4.找到小于tmp元素的位置后,插入到该元素的后面,就完成了一次插入排序

图片演示:

重复上述步骤,直到排序结束。

二、代码

复制代码
void InsertSort(int* arr, int n)  //n是数组的大小  n = sizeof(arr)/sizeof(int)
{
	for (int i = 0; i < n - 1; i++)  //i < n - 1而不是小于n是为了避免越界访问
	{
		int end = i; //到[0,end]是一个有序的数组
		int tmp = arr[end + 1];
		while (end >= 0)
		{
			if (arr[end] > tmp)
			{
				arr[end + 1] = arr[end];
				end--;
			}
			else
			{
				break;
			}
		} //出循环时,end指向的是小于tmp元素的位置。当end = -1时,
            代表tmp的值是在有序数组中最小的值
		arr[end + 1] = tmp;
	}
}
相关推荐
枫叶v.22 分钟前
Agent 分层存储架构设计:从记忆方法到中间件选型
开发语言·python
sleven fung2 小时前
MinerU与BabelDOC与KTransformers与OpenAI API库
开发语言·python·ai·langchain
萤萤七悬2 小时前
【Python笔记】AI帮实现CLI工具-使用argparse.ArgumentParser接收命令参数
开发语言·笔记·python
iCxhust2 小时前
C# 命令行指令 查看二进制文件
开发语言·单片机·嵌入式硬件·c#·proteus·微机原理·8088单板机
csdn_aspnet2 小时前
Java 霍尔分区算法(Hoare‘s Partition Algorithm)
java·开发语言·算法
诸葛务农2 小时前
道路行驶条件下电动汽车永磁电机的有效使用寿命及永磁体的失效和回收再利用(下)
java·开发语言·算法
oort1233 小时前
VLStream:全开源决策式AI视频平台,赋能企业构建自主可控、降本增效的智能视觉应用介绍
大数据·开发语言·人工智能·开源·音视频·数据库架构
c238563 小时前
c/c++中的多态(上)
开发语言·c++
彷徨而立3 小时前
【C++】介绍 std::ifstream 输入文件流
开发语言·c++
罗超驿3 小时前
13.JavaScript 新手入门指南:语法、变量、流程控制全解析
开发语言·javascript