解题思路:
结构体的方法就不多说了,当然不使用结构题也是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 人评分
输出正反三角形 (C语言代码)格式错误!!!浏览:1140 |
文科生的悲哀 (C语言代码)浏览:1398 |
1126题解浏览:578 |
C二级辅导-统计字符 (C语言代码)浏览:627 |
简单的a+b (C语言代码)浏览:434 |
A+B for Input-Output Practice (I) (C语言代码)浏览:570 |
快速排序算法1浏览:877 |
C语言程序设计教程(第三版)课后习题7.4 (C语言代码)浏览:500 |
很简单,,题解1041:C语言程序设计教程(第三版)课后习题9.8 (C语言代码)浏览:586 |
平方数问题,oj一直是wrong answer浏览:738 |