结构体排序 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<<" "

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

相关推荐
木心月转码ing44 分钟前
Hot100-Day10-T438T438找到字符串中所有字母异位词
算法
HelloReader1 小时前
Wi-Fi CSI 感知技术用无线信号“看见“室内的人
算法
颜酱4 小时前
二叉树分解问题思路解题模式
javascript·后端·算法
qianpeng8975 小时前
水声匹配场定位原理及实验
算法
董董灿是个攻城狮17 小时前
AI视觉连载8:传统 CV 之边缘检测
算法
blasit1 天前
笔记:Qt C++建立子线程做一个socket TCP常连接通信
c++·qt·tcp/ip
AI软著研究员1 天前
程序员必看:软著不是“面子工程”,是代码的“法律保险”
算法
FunnySaltyFish1 天前
什么?Compose 把 GapBuffer 换成了 LinkBuffer?
算法·kotlin·android jetpack
颜酱1 天前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法
地平线开发者2 天前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶