直接选择排序

直接选择排序(Selection Sort)特性总结

  1. 理解难度:算法思想非常直观、易于理解。

    • 每一轮从未排序部分中选出最小(或最大)元素,放到已排序部分的末尾。
    • 但由于效率较低,在实际工程中很少使用
  2. 时间复杂度

    • **最好 / 平均 / 最坏情况均为 O(n\^2) **
    • 原因:无论输入数据如何,都需要进行约 \\frac{n(n-1)}{2} 次比较。
  3. 空间复杂度

    • ** O(1) **(原地排序)
    • 仅使用常数个额外变量,无需额外存储空间。
c 复制代码
void SelectSort(int *arr,int n)
{
	int begin = 0;
	int end = n - 1;
	while(begin<end)
	{
		int max = end, min = begin;//让max和min跟随begin和end更新,避免因为没有发生交换等情况最后导致错误交换值。
		for (int i = begin;i <= end;i++)
		{

			if (arr[i] > arr[max])
			{
				 max = i;//选择排序只交换当前值与最值,如果此处直接交换,会造成多次交换,破坏原有的序列。
			}
			if (arr[i]<arr[min])
			{
				 min = i;
			}

		}
		Swap(&arr[max], &arr[end]);
		if (min == end)//先选择最大值时如果最小值在序列尾,会造成交换最小值前,最小值的下标发生变化,此时需要变更下标,若选择先排最小值,同理要防止最大值出现在begin位置时造成的下标偏移
		{
			min = max;
		}
		Swap(&arr[min], &arr[begin]);
		begin++;
		end--;
	}
}

该代码中为直接选择排序的优化方法------双向选择排序,同时对首端和尾端选择,可以提升选择排序效率

相关推荐
AI小老六16 分钟前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术1 小时前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize2 小时前
初识DFS 与 BFS:递归、队列与图遍历
算法
罗西的思考15 小时前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
CSharp精选营18 小时前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
美团技术团队18 小时前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法
To_OC1 天前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC1 天前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
BadBadBad__AK2 天前
线段树维护区间 k 次方和
c++·数学·算法·stl