排名(浙大上机2005)

Problem Description
今天的上机考试虽然有实时的Ranklist,但上面的排名只是根据完成的题数排序,没有考虑
每题的分值,所以并不是最后的排名。给定录取分数线,请你写程序找出最后通过分数线的
考生,并将他们的成绩按降序打印。
 
Input
测试输入包含若干场考试的信息。每场考试信息的第1行给出考生人数N ( 0 < N
< 1000 )、考题数M ( 0 < M < = 10 )、分数线(正整数)G;第2行排序给出第1题至第M题的正整数分值;以下N行,每行给出一
名考生的准考证号(长度不超过20的字符串)、该生解决的题目总数m、以及这m道题的题号
(题目号由1到M)。
当读入的考生人数为0时,输入结束,该场考试不予处理。

 

Output
对每场考试,首先在第1行输出不低于分数线的考生人数n,随后n行按分数从高
到低输出上线考生的考号与分数,其间用1空格分隔。若有多名考生分数相同,则按他们考
号的升序输出。
 
Sample Input
4 5 25
10 10 12 13 15
CS004 3 5 1 3
CS003 5 2 4 1 3 5
CS002 2 1 2
CS001 3 2 3 5 1 2 40 10 30
CS001 1 2
2 3 20
10 10 10
CS000000000000000001 0
CS000000000000000002 2 1 2 0

 

Sample Output
3
CS003 60
CS001 37
CS004 37
0
1
CS000000000000000002 20
View Code
 1 #include <iostream>
2 #include <fstream>
3 #include <algorithm>
4 #include <vector>
5 #include <string>
6
7 using namespace std;
8
9 #define N 1000
10 #define M 11
11
12 int queScore[M];
13
14 // 在结构体里重载<操作符是不是就能不用再写比较函数了呢?不懂STL
15 typedef struct stu
16 {
17 char name[21]; // 开始时20,结果最后一组sample就除了问题
18 int score;
19 }stu;
20
21 // 自定义比较函数,已按题目要求对学生信息进行排序
22 bool comp(const stu &a, const stu &b)
23 {
24 if (a.score != b.score)
25 return a.score > b.score; // 按分数升序排序
26 else
27 return strcmp(a.name,b.name) < 0; // 分数相等时按姓名降序排序
28 }
29
30 vector<stu> st;
31
32 int main(void)
33 {
34 int n,m,line;
35 //ifstream cin("hello.txt");
36
37 while (cin >> n && n != 0)
38 {
39 int i,j,k,ansNum; // 因为用VC6.0,所以在for里声明i的话就会报重复声明
40 stu temp;
41 st.clear(); // 别忘清空
42
43 cin >> m >> line;
44 for (i = 0; i < m; i++)
45 cin >> queScore[i];
46
47 for (i = 0; i < n; i++)
48 {
49 cin >> temp.name;
50 temp.score = 0;
51 cin >> ansNum;
52 for (j = 0; j < ansNum; j++)
53 {
54 cin >> k;
55 temp.score += queScore[k-1];
56 }
57 st.push_back(temp);
58 }
59
60 // 排序
61 sort(st.begin(), st.end(), comp);
62
63 string str;
64 char s[100];
65 int count = 0;
66
67 // 如果不打印通过的人数的话直接遍历就打印考生信息了
68 // 可是要求打印,遍历两边的话明显费时些,用空间换时间
69 // 把要打印的信息“缓存”起来先
70 for (vector<stu>::iterator it = st.begin(); it != st.end(); it++)
71 {
72 if ((*it).score >= line)
73 {
74 sprintf(s,"%s %d\n", (*it).name, (*it).score);
75 str.append(s);
76 count++;
77 }
78 else
79 break;
80 }
81 cout << count << endl;
82 if (count > 0)
83 cout << str;
84 }
85 return 0;
86 }
posted @ 2012-02-29 17:53  吞枣  Views(306)  Comments(0)    收藏  举报