结构体排序 C++ 蓝桥杯

成绩排序

cpp 复制代码
#include<iostream>
#include<algorithm>
using namespace std;
struct stu {
	string name;//名字
	int grade;//成绩
};
stu a[30];
bool cmp(stu l, stu r) {
	if (l.grade != r.grade) return l.grade > r.grade;
	return l.name < r.name;
}
int main() {
	int n; cin >> n;
	for (int i = 1; i <= n; i++) cin >> a[i].name >> a[i].grade;
	sort(a + 1, a + n + 1, cmp);

	for (int i = 1; i <= n; i++) cout << a[i].name << " " << a[i].grade << endl;

	return 0;
}

成绩排序思路:输入n名学生的名字和成绩,所以开结构体类型,学生包含两个属性,姓名和成绩,排序算法在打比赛时常用的是sort(在头文件algorithm下使用)。涉及到自己写的结构体类型时,必须要重写排序规则即代码中的bool cmp(stu l,stu r)函数作为sort的第三个参数。

bool cmp(stu l,stu r) 先是比较成绩,如果成绩不同,返回成绩高的在前。再返回名字字典序小的。

sort(a+1,a+n+1,cmp) ------ a+1:待排序区间的首元素------ a+n+1:待排序区间尾元素后一位------ cmp:比较器,排序规则。

最后输出排好序的数组里的每个元素的名字+空格+对应的成绩+换行。

明明的随机数

cpp 复制代码
#include<iostream>
#include<set>
using namespace std;
int main() {
	set<int>s;//集合-去重+排序
	int n; cin >> n;
	for (int i = 1; i <= n; i++) {
		int x; cin >> x;
		s.insert(x);
	}
	cout << s.size() << endl;
	for (auto i : s) cout << i << " ";
	return 0;
}

明明的随机数方法一

set解决思路:直接用集合,因为本题要对一组数去重,并且排序,从小到大。集合会自动对传入的数进行去重和排序。最后输出集合里的元素个数,换行输出排好了的集合每一个元素。

集合知识点:stl容器之一 ------ standard template library ------ 标准模板库

集合头文件:include<set>

集合的创建:set<int>s; ------关键字<集合里元素类型>集合名

向集合里插入元素:s.insert(x)------向集合里插入值x

求集合元素个数:s.size()------直接输出去重排序后的集合元素个数

集合输出不能用下标:增强for循环------for(auto i:s) ------auto i:s------自动 识别集合s里的每个元素类型,让i去从头到尾遍历每个元素。所以直接输出 i ,cout<<i<<" ";

cpp 复制代码
#include<iostream>
using namespace std;
const int N = 1e3 + 10;
int cnt[N];
int main() {
	int n; cin >> n;
	//  计数排序
	for (int i = 1; i <= n; i++) {
		int x; cin >> x;
		cnt[x]++;
	}
	//  统计去重后有多少个元素
	int ans = 0;
	for (int i = 0; i <= 1000; i++) {
		if (cnt[i] != 0) ans++;
	}
	cout << ans << endl;
	//  输出去每个元素(去重)
	for (int i = 0; i <= 1000; i++) {
		if (cnt[i] != 0) cout << i << " ";
	}

	return 0;
}

明明的随机数方法二:

计数排序解决思路:

①开一个计数数组,大小由所有可能出现的数的最大值决定。循环输入每一个数,将每一个数作为计数数组的下标,每个数出现次数作为这个元素的值。

②循环遍历每一个下标,判断a[i]元素值是否不等于0,不等于0就将ans(记录去重后的总数)++,输出ans及换行

③循环遍历每一个下标,判断a[i]元素值是否不等于0,不等于0就直接输出下标i,cout<<i<<" "

完结!!!⠀՞⸝⸝. .⸝⸝՞˳ഒ

相关推荐
YE_lou13 分钟前
【蓝桥杯嵌入式】2_LED
stm32·嵌入式硬件·蓝桥杯
hurrycry_小亦14 分钟前
洛谷网站: P3029 [USACO11NOV] Cow Lineup S 题解
算法
一期一祈^2 小时前
C++SLT(三)——list
开发语言·c++·list
LUCIAZZZ2 小时前
Hot100之图论
java·数据结构·算法·leetcode·深度优先·图论
tan180°2 小时前
DS图(中)(19)
开发语言·数据结构·c++·算法·深度优先·图论
CodeClimb3 小时前
【华为OD-E卷 - 115 数组组成的最小数字 100分(python、java、c++、js、c)】
java·javascript·c++·python·华为od
CodeClimb3 小时前
【华为OD-E卷 - 114 找最小数 100分(python、java、c++、js、c)】
java·javascript·c++·python·华为od
风靡晚3 小时前
论文解读:《基于TinyML毫米波雷达的座舱检测、定位与分类》
人工智能·算法·分类·信息与通信·信号处理
JNU freshman3 小时前
蓝桥杯思维训练(五)
算法·蓝桥杯