直接选择排序

直接选择排序(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--;
	}
}

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

相关推荐
小O的算法实验室1 天前
2026年ASOC,基于深度强化学习的无人机三维复杂环境分层自适应导航规划方法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
‎ദ്ദിᵔ.˛.ᵔ₎1 天前
LIST 的相关知识
数据结构·list
M--Y1 天前
Redis常用数据类型
数据结构·数据库·redis
郭涤生1 天前
STL vector 扩容机制与自定义内存分配器设计分析
c++·算法
༾冬瓜大侠༿1 天前
vector
c语言·开发语言·数据结构·c++·算法
Ricky111zzz1 天前
leetcode学python记录1
python·算法·leetcode·职场和发展
汀、人工智能1 天前
[特殊字符] 第58课:两个正序数组的中位数
数据结构·算法·数据库架构··数据流·两个正序数组的中位数
liu****1 天前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯
汀、人工智能1 天前
[特殊字符] 第79课:分割等和子集
数据结构·算法·数据库架构·位运算·哈希表·分割等和子集
汀、人工智能1 天前
[特殊字符] 第74课:完全平方数
数据结构·算法·数据库架构·图论·bfs·完全平方数