您的位置:首页 > 其它

PAT乙级1004. 成绩排名 (20)

2017-10-15 13:09 309 查看
1004. 成绩排名 (20)
读入n名学生的姓名、学号、成绩,分别输出成绩最高和成绩最低学生的姓名和学号。
输入格式:每个测试输入包含1个测试用例,格式为

第1行:正整数n

第2行:第1个学生的姓名 学号 成绩

第3行:第2个学生的姓名 学号 成绩

... ... ...

第n + 1行:第n个学生的姓名 学号 成绩

其中姓名和学号均为不超过10个字符的字符串,成绩为0到100之间的一个整数,这里保证在一组测试用例中没有两个学生的成绩是相同的。
输出格式:对每个测试用例输出2行,第1行是成绩最高学生的姓名和学号,第2行是成绩最低学生的姓名和学号,字符串间有1空格。
输入样例:

3

Joe Math990112 89

Mike CS991301 100

Mary EE990830 95
输出样例:

Mike CS991301

Joe Math990112

这里是一篇vector的简单用法:http://blog.csdn.net/wang1997hi/article/details/78239993

#include<iostream>
#include<string>
#include<vector>
using namespace std;
int main()
{
struct student {	//定义一种包含学生信息的类型
string name;
string number;
int score;
};
student temp;      //用来临时存储刚输入的学生信息
vector<student> stu;	//创建student vector,类似于数组
int i,N,max=0,min=0;	//max和min分别代表分数最高和最低的学生的序号
cin >> N;				//学生人数
for (i = 0; i < N; i++)
{
cin >> temp.name >> temp.number >> temp.score;	//输入学生的信息
stu.push_back(temp);							//把学生信息压入数组
if (stu[i].score>stu[max].score)				//一旦发现新的分数比之前存储的最高分高,就用新的替换掉
max = i;
if (stu[i].score<stu[min].score)				//一旦发现新的分数比之前存储的最低分低,就用新的替换掉
min = i;
}
cout << stu[max].name << " " << stu[max].number << endl;//输出信息
cout << stu[min].name << " " << stu[min].number;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: