题目描述:
1004 成绩排名 (20 分)
读入 n(>0)名学生的姓名、学号、成绩,分别输出成绩最高和成绩最低学生的姓名和学号。
输入格式:
每个测试输入包含 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
分析:此题主要考察了结构体的相关知识。
结果:
提交时间 | 状态 | 分数 | 题目 | 编译器 | 耗时 | 用户 |
---|---|---|---|---|---|---|
2019/1/13 14:17:28 | 答案正确 |
20 | 1004 | C++ (g++) | 3 ms | 方人也几点 |
测试点 | 结果 | 耗时 | 内存 |
---|---|---|---|
0 | 答案正确 | 3 ms | 368 KB |
1 | 答案正确 | 3 ms | 384 KB |
2 | 答案正确 | 3 ms | 384 KB |
代码:
#include<iostream>
using namespace std;
struct Student{
char name[11];
char id[11];
int grade;
};
int main(){
int n;
int i,mn,mx,grade_Min = 999,grade_Max = 0;
/*输入*/
cin>>n;
Student stu[n];
for(i=0;i<n;i++){
cin>>stu[i].name>>stu[i].id>>stu[i].grade;
}
/*获得成绩最低的学生姓名和学号*/
for(i=0;i<n;i++){
if(stu[i].grade<grade_Min) {grade_Min = stu[i].grade;mn=i;}
}
/*获得成绩最高的学生姓名和学号*/
for(i=0;i<n;i++){
if(stu[i].grade > grade_Max || stu[i].grade == grade_Max) {grade_Max = stu[i].grade;mx=i;}
}
/*输出*/
cout<<stu[mx].name<<" "<<stu[mx].id<<endl;
cout<<stu[mn].name<<" "<<stu[mn].id<<endl;
return 0;
}