【数据结构 | 直接选择排序】

直接选择排序

基本思路

直接插入排序(StraightInsertionSort)的基本操作是将一个记录插入到已经排好序的有序表中,从而得到一个新的、记录数增1的有序表。

c 复制代码

我们可以同时从数组的头部和尾部同时进行排序工作:

我们首先使用maxmin 两个变量来记录最大和最小值,初始化同时为数组第一个数字

然后通过遍历整个数组,更新max和min

然后吧最小数 交换至数组头部.吧最大数 交换至数组尾部

缩短数组范围,再重复以上步骤,即可。

直接插入排序

c 复制代码

按照以上步骤完成代码。

我们有如下数组需要排序

c 复制代码

结果如下:

为什么出错了?

c 复制代码

修改如下:

结果如下:

SelectSort

c 复制代码
//直接插入排序
void SelectSort(int* a, int n)
{
	int begin = 0, end = n - 1, i;
	while (begin < end)
	{
		int min = begin, max = begin;
		//同时排头和尾
		for (i = begin + 1; i <= end; i++)
		{
			if (a[i] < a[min])
				min = i;
			if (a[i] > a[max])
				max = i;
		}
		Swap(&a[min], &a[begin]);
		if (begin != max)
		{
			Swap(&a[max], &a[end]);
		}

		begin++;
		end--;
	}
}
相关推荐
来生硬件工程师11 小时前
【STM32笔记】:P04 断言的使用
c语言·笔记·stm32·单片机·嵌入式硬件·硬件架构·硬件设计
·白小白11 小时前
力扣(LeetCode) ——11.盛水最多的容器(C++)
c++·算法·leetcode
yuuki23323312 小时前
【C语言】文件操作(附源码与图片)
c语言·后端
沐浴露z13 小时前
【JVM】详解 垃圾回收
java·jvm·算法
秦.赢渠梁13 小时前
各种通信(三):GPS模块数据解析
c语言
代码欢乐豆13 小时前
编译原理机测客观题(7)优化和代码生成练习题
数据结构·算法·编译原理
祁同伟.14 小时前
【C++】二叉搜索树(图码详解)
开发语言·数据结构·c++·容器·stl
Scc_hy14 小时前
强化学习_Paper_2000_Eligibility Traces for Off-Policy Policy Evaluation
人工智能·深度学习·算法·强化学习·rl
Joy T14 小时前
Solidity智能合约存储与数据结构精要
数据结构·区块链·密码学·智能合约·solidity·合约function
leke200315 小时前
2025年10月17日
算法