蓝桥杯 选择排序

选择排序的思想

选择排序的思想和冒泡排序类似,是每次找出最大的然后直接放到右边对应位置,然后将最

右边这个确定下来(而不是一个一个地交换过去)。

再来确定第二大的,再确定第三大的...

对于数组a[],具体的来说,每次确定操作(假设当前要确定的是i位置)就是从左往右扫描,

计算出最大元素的下标max_id, 最后执行一次swap(a[max_id],a[i])将两项交换即可。

第一次确定操作是将a[1]~a[n]中最大的放到a[n];

第二你确定操作是将a[1]~a[n-1]中最大的放到a[n-1]。

类推(类似地,如果你想先把最小的放到左边也是可以的),时间复杂度为O(n^2)。

选择排序的实现

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N=1e3+9;
int a[N];
int main(){
	int n;cin>>n;
	for(int i=1;i<=n;i++)cin>>a[i];
	
	//i表示当前要确定的位置 
	for(int i=n;i>=1;i--){
		int max_id=1;//初始化为1
		//j从左往右扫求出max_id
		for(int j=1;j<=i;j++){
			if(a[j]>a[max_id])max_id=j;
		} 
		swap(a[max_id],a[i]);
	}
	
	//输出
	for(int i=1;i<=n;i++) cout<<a[i]<<" \n"[i==n];
	return 0; 
}

例题讲解

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N=1e3+9;
int a[N];
int main(){
	int n;cin>>n;
	for(int i=1;i<=n;i++)cin>>a[i];
	for(int i=n;i>=1;i--){
		int max_id=1;
		for(int j=1;j<=i;j++){
			if(a[j]>a[max_id])max_id=j;
		} 
		swap(a[max_id],a[i]);
	}
	for(int i=1;i<=n;i++) cout<<a[i]<<" \n"[i==n];
	return 0; 
}
相关推荐
老四啊laosi30 分钟前
[C++进阶] 24. 哈希表封装unordered_map && unordered_set
c++·哈希表·封装·unordered_map·unordered_set
2301_7644413335 分钟前
LISA时空跃迁分析,地理时空分析
数据结构·python·算法
东北洗浴王子讲AI36 分钟前
GPT-5.4辅助算法设计与优化:从理论到实践的系统方法
人工智能·gpt·算法·chatgpt
妙为1 小时前
银河麒麟V4下编译Qt5.12.12源码
c++·qt·国产化·osg3.6.5·osgearth3.2·银河麒麟v4
Billlly1 小时前
ABC 453 个人题解
算法·题解·atcoder
玉树临风ives1 小时前
atcoder ABC 452 题解
数据结构·算法
feifeigo1232 小时前
基于马尔可夫随机场模型的SAR图像变化检测源码实现
算法
weixin_446023562 小时前
C语言:面向过程、应用底层开发、跨平台的通用程序设计语言
c语言·跨平台·数据类型·底层开发·面向过程
fengfuyao9852 小时前
基于STM32的4轴步进电机加减速控制工程源码(梯形加减速算法)
网络·stm32·算法
无敌昊哥战神3 小时前
深入理解 C 语言:巧妙利用“0地址”手写 offsetof 宏与内存对齐机制
c语言·数据结构·算法