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

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

相关推荐
trust Tomorrow11 分钟前
每日一题-力扣-2278. 字母在字符串中的百分比 0331
算法·leetcode
Chiyamin17 分钟前
C++面向对象速览(三)
c++
Tadecanlan22 分钟前
[C++面试] 智能指针面试点(重点)续4
开发语言·c++·面试
Chiyamin23 分钟前
C++面向对象速览(一)
c++
Lecea_L25 分钟前
你能在K步内赚最多的钱吗?用Java解锁最大路径收益算法(含AI场景分析)
java·人工智能·算法
Tony8827 分钟前
热题100 - 394. 字符串解码
java·算法
GOTXX28 分钟前
BoostSiteSeeker项目实战
前端·c++·后端·mysql·搜索引擎·项目实战·boost
Lecea_L33 分钟前
🔍 找到数组里的“节奏感”:最长等差子序列
java·算法
是Dream呀35 分钟前
ResNeXt: 通过聚合残差变换增强深度神经网络
人工智能·算法
胡乱儿起个名1 小时前
C++的指针数组、数组指针和指针数组指针
开发语言·c++