【数据结构 | 直接插入排序】

直接插入排序

思路

扑克牌是我们几乎每个人都可能玩过的游戏。最基本的扑克玩法都是一边摸牌,边理牌。假如我们拿到了这样一手牌,如下图所示:

理牌的方法都是不用教的。将3和4移动到5的左侧,再将2移动到最左侧,顺序就算是理好了。这里,我们的理牌方法,就是直接插入排序法。

首先,我们由上动图可知:
插入排序 是吧一个数组里的每一个数字 往前遍历,比较大小,若排升序 ,则若该数字小于 前一个数字,则吧前一个数字往后移动自己往前走一步

当不小于前面这个数字时,则吧该数字插到空位

重复以上步骤。

我们规定,从第一个数字开始,第二个数字与第一个相比,若小,则交换位置。

所以整体的遍历,i 应该从 0 开始,i < n-1.

直接插入排序

InsertSort.c

c 复制代码
//直接插入排序
void InsertSort(int* a, int n)
{
	for (int i = 0; i < n - 1; i++)
	{
		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;
	}
}
c 复制代码

代码测试

结果:

相关推荐
代码游侠4 分钟前
学习笔记——线程控制 - 互斥与同步
linux·运维·笔记·学习·算法
李子园的李6 分钟前
Java函数式接口——渐进式学习
java
yaoh.wang7 分钟前
力扣(LeetCode) 66: 加一 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·跳槽
running up9 分钟前
Spring Bean生命周期- BeanDefinition 加载与 BeanFactoryPostProcessor BeanPostProcessor
java·后端·spring
聆风吟º14 分钟前
【数据结构手札】顺序表实战指南(一):线性表定义 | 顺序表定义
数据结构·顺序表·线性表
222you19 分钟前
Java线程的三种创建方式
java·开发语言
脸大是真的好~25 分钟前
计算机408基础相关面试题-备用,不推荐
java
小费的部落25 分钟前
Excel 在Sheet3中 匹配Sheet1的A列和Sheet2的A列并处理空内容
java·前端·excel
咘噜biu26 分钟前
多租户动态数据源插件dynamic-datasource简介
java·mybatisplus·动态数据源·多租户
漫漫求28 分钟前
Java内存模型【JMM】、JVM内存模型
java·开发语言·jvm