C语言实现-直接插入排序(带图详解)

本文详细介绍了直接插入排序的基本思想,通过打扑克牌的例子演示其工作原理,并提供了一段C++代码实现。此外,还总结了该排序算法的性质,包括时间复杂度、空间复杂度、稳定性等。

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

直接插入排序的实现

一、基本思想

像现实中打扑克牌一样,抓牌就是直接插入排序的很好例子,每抓一张牌插入到合适的位置,最后得到一个有序序列。所以直接插入排序的思想就是把待排序的数字逐个插入到已经排好的有序序列里,最后得到一个新的有序序列。

二、实现思路

①先进行单趟排序:使一个有序区间,插入一个数继续有序,使其依然保持有序。

②再排多趟排序:多趟排序后序列越来越接近有序,最后得到有序序列。

三、图形解释过程

四、代码实现

//直接插入排序
void insertsort(int* a, int n)
{
    //多趟数排序,最后为一个有序序列
	for (int i = 0; i < n - 1; i++)
	{
      //单趟排序 [0,end]有序,把值end+1的值插入后,依然有序	
	    int end=i;
		int tmp = a[end + 1];
		while (end >= 0)
		{
			if (tmp < a[end])
			{
				a[end + 1] = a[end];
				end--;
			}
			else
				break;
		}
		a[end + 1] = tmp;
	}

}

五、直接插入排序性质总结

1. 元素集合越接近有序,直接插入排序算法的时间效率越高
2. 时间复杂度:O(N^2)
3. 空间复杂度:O(1),它是一种稳定的排序算法
4. 稳定性:稳定

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值