蓝桥杯 选择排序

选择排序的思想

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

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

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

对于数组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; 
}
相关推荐
程序猿编码3 小时前
PRINCE算法的密码生成器:原理与设计思路(C/C++代码实现)
c语言·网络·c++·算法·安全·prince
高洁013 小时前
具身智能-视觉语言导航(VLN)
深度学习·算法·aigc·transformer·知识图谱
Hacker_Oldv3 小时前
API 自动化测试难点总结与分享
自动化测试·软件测试·职场和发展
Croa-vo4 小时前
TikTok 数据工程师三轮 VO 超详细面经:技术深挖 + 建模推导 + 压力测试全记录
javascript·数据结构·经验分享·算法·面试
蘑菇小白4 小时前
时间复杂度
数据结构·算法
czlczl200209254 小时前
算法:组合问题
算法·leetcode·职场和发展
CoderYanger4 小时前
优选算法-字符串:63.二进制求和
java·开发语言·算法·leetcode·职场和发展·1024程序员节
charlie1145141914 小时前
深入理解C/C++的编译链接技术6——A2:动态库设计基础之ABI设计接口
c语言·开发语言·c++·学习·动态库·函数
Cx330❀4 小时前
C++ STL set 完全指南:从基础用法到实战技巧
开发语言·数据结构·c++·算法·leetcode·面试
white-persist4 小时前
【攻防世界】reverse | Reversing-x64Elf-100 详细题解 WP
c语言·开发语言·网络·python·学习·安全·php