咖啡


私信TA

用户名:Tianxn

访问量:128012

签 名:

十年OI一场空,不开LL见祖宗。

等  级
排  名 8
经  验 26033
参赛次数 10
文章发表 197
年  龄 22
在职情况 学生
学  校 西安电子科技大学
专  业 软件工程

  自我简介:

解题思路:

结构体的方法就不多说了,当然不使用结构题也是ok的,比如间接排序。

这里我们来说一种骚操作:

                首先,三科分数总和是小于等于300,即最多三位数

                其次,语文学科的分数小于等于100,即最多三位数

                再次,学员编号是小于等于300的(只是这里题目好像没有数据范围,其他oj的范围都是300),即最多三位数

                那么,把总分、语文分数、学号可以组合成一个整数,总分*1000000+语文*1000+999-学号。

                因为排序规则是:先按总分从高到低排序,如果两个同学总分相同,再按语文成绩从高到低排序,如果两个同学总分和语文成绩都相同,那么规定学号小的同学排在前面。所以存储999-i的值那么从大到小排序实际上就是从小到大排序哦。

                对于任意一个组合的整数a:学号=999 -a%1000,总分=a/1000000。


注意事项:
                拿样例自己先试试呗~
参考代码:

#include <iostream>
#include <algorithm>
using namespace std;

int main() {
	int n, x, y, z, p[310];
	cin >> n;
	for (int i = 1; i <= n; ++i) {
		cin >> x >> y >> z;
		p[i] = (x + y + z) * 1000000 + x * 1000 + 999 - i;
	}
	sort(p + 1, p + n + 1);
	for (int i = n; i >= n - 4; --i)
		cout << 999 - p[i] % 1000 << " " << p[i] / 1000000 << endl;
	return 0;
}


 

0.0分

37 人评分

  评论区