直接插入排序源代码的基础讲解

本文深入解析直接插入排序算法,详细介绍了其源代码实现过程。通过具体步骤解释如何将待排序元素与已排序序列进行比较并调整位置,确保序列始终处于有序状态。适合初学者理解直接插入排序的工作原理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

**

直接插入排序源代码的基础讲解

建议直接看讲解存在疑惑的可以先看看这个~具体的分析参照另一篇高阅读文章
源代码

void InsertSort( int a[],int n)
{
    int i,j,tmp;
    for(i=1;i<n;i++)
    {
        tmp=a[i];
        j=i-1;
        while(j>=0&&a[j]>tmp)
        {
            a[j+1]=a[j];
            j--;
        }
        a[j+1]=tmp;
    }
}```

## 详解
void InsertSort(int a[],int n)//传入了数组的指针和数组的大小n,函数体里可以对这两个变量进行操作*/
{
	int i,j,tmp;//定义i,j为数组的指针,tmp为存储数据的临时变量
	for(int i=1;i<n;i++)//i从1开始,即从数组的第二个元素开始,因为第一个元素没有相对大小,不用排序,i<n作为上限,到数组里的最后一个元素结束。*/
	{
		tmp=a[i];/*把a数组中第i个元素,即待排序元素复制到tmp中*/
		j=i-1;/*j指针一开始指向数组中待排序元素的前一个元素,也就是已经有序的序列的最后一个元素*/
		while(j>=0&&a[j]>=tmp)
		/*从待排序的前一个元素开始,如果发现这个元素比待排序元素(a[i])要大,那么则把这个元素复制到后一个元素的位置里,把原来放待排序元素的位置(a[i])给挤掉。*/
		/*如果待排序元素大于已经有序的序列里面最大的元素,那么很好,不用移动元素,直接把待排序元素加入已有序的序列的最后即可*/
		{
			a[j+1]=a[j];
			j--;
		}/*这里的循环结束之后,j多做了一次--,所以最终指向了理想位置的前一个位置*/
		a[j+1]=tmp;/*所以最终要把tmp插入到a中第j+1个位置。
	}
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值