1004 成绩排名 (20分)
读入 名学生的姓名、学号、成绩,分别输出成绩最高和成绩最低学生的姓名和学号。
输入格式:
每个测试输入包含 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
个人感觉用结构体比较好。无需建立结构体数组,因为这道题有一个成绩的比较关系外加只输出两行值,在这里只建立了三个结构体对象,stu_max用于存储成绩最高的学生类型,stu_min用于存储成绩最低的学生类型,stu用于每次输入与stu_max和stu_min作比较,如果输入值比stu_max高,则将stu赋值给stu_max,如果输入值比stu_min低,则把stu赋值给stu_min。
C++
#include<iostream>
using namespace std;
struct Student {
string name;//姓名
string stu_num;//学号
int grade;//分数
};
int main()
{
Student stu_max, stu_min, stu;//记录成绩最高,成绩最低,输入学生
int n;
cin >> n;//输入整数
for (int i = 0; i < n; i++)
{
if (i == 0)
{
cin >> stu_max.name >> stu_max.stu_num >> stu_max.grade;
stu_min = stu_max;
stu = stu_max;
}
else
cin >> stu.name >> stu.stu_num >> stu.grade;
if (stu.grade > stu_max.grade)
stu_max = stu;
if (stu.grade < stu_min.grade)
stu_min = stu;
}
cout << stu_max.name << " " << stu_max.stu_num << endl;
cout << stu_min.name << " " << stu_min.stu_num << endl;
return 0;
}