【数据结构】选择排序

  1. 选择排序的基本思想:
    每⼀次从待排序的数据元素中选出最⼩(或最⼤)的⼀个元素,存放在序列的起始位置,直到全部待
    排序的数据元素排完。

直接选择排序的动图演示


  1. 选择排序的思路
  • 准备我们给定一个随机排列的数组arr[],在数组中找好元素对应的下标
  • 在待排序的数组元素中,找出最大(最小)的数据元素;
  • 如果找出来的这个最大(最小)数据元素不是这个数组中的第一个元素,则与数组中的最后一个元素(第一个元素)进行交换;
  • 交换完之后已排序的元素+1,待排序的元素-1,再从待排序的元素序列中重复,知道集合剩下最后一个元素最小(最大)元素;

大致思路代码:

选择排序总体思路解析

  • 定义最大和最小都在第一个元素,后续遍历找出最大(最小)
  • 遍历完之后找出的maxi和mini分别和end和begin交换
  • 注意:为了避免maxi和begin都在同一个位置。遍历完之后,mini与begin交换后,maxi反倒成了最小的元素。我们给予判断条件:如果maxi和begin同一位置,那么将mini的值给maxi,也不妨碍后续交换

代码实现:

c 复制代码
void SelectSort(int* arr, int n)
{
	int begin = 0;//首位置
	int end = n - 1;//末位置
	while (begin < end)
	{
		int maxi = begin, mini = begin;//最大值和最小值的定义,每次循环都让maxi和mini处于首元素
		for (int i = begin + 1; i <= end; i++)
		{
			if (arr[i] > arr[maxi])
			{
				maxi = i;
			}
			if (arr[i] < arr[mini])
			{
				mini = i;
			}
		}
		if (maxi == begin)//为了防止出现交换差错,让maxi成了最小
		{
			maxi = mini;
		}
		Swap(&arr[mini], &arr[begin]);
		Swap(&arr[maxi], &arr[end]);
		++begin;
		--end;
	}
}

时间复杂度:O(n^2)

相关推荐
一起养小猫4 分钟前
Flutter for OpenHarmony 进阶:递归算法与数学证明深度解析
算法·flutter
赛博云推-Twitter热门霸屏工具4 分钟前
Twitter 搜索霸屏的关键词工程方法——从算法理解到赛博云推的系统化执行
算法·twitter·dreamweaver
罗湖老棍子18 分钟前
【区间DP】括号序列:如何求解最长合法子序列?(POJ 2955)
算法·动态规划·区间dp·区间动态规划·端点匹配型
王德博客22 分钟前
【实现常见排序算法】直接插入排序的算法思想
数据结构·算法·排序算法
m0_5648768423 分钟前
分布式训练DP与DDP
人工智能·深度学习·算法
纤纡.23 分钟前
逻辑回归实战进阶:交叉验证与采样技术破解数据痛点(一)
算法·机器学习·逻辑回归
重生之后端学习26 分钟前
146. LRU 缓存
java·数据结构·算法·leetcode·职场和发展
程曦曦28 分钟前
原地删除有序数组重复项:双指针法的艺术与实现
数据结构·算法·leetcode
你怎么知道我是队长29 分钟前
C语言---排序算法6---递归归并排序法
c语言·算法·排序算法
智驱力人工智能41 分钟前
景区节假日车流实时预警平台 从拥堵治理到体验升级的工程实践 车流量检测 城市路口车流量信号优化方案 学校周边车流量安全分析方案
人工智能·opencv·算法·安全·yolo·边缘计算