读入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
这道题是一道基础的结构题,运用结构的知识就可以解答,代码如下:
#include<iostream>
using namespace std;
int main()
{
struct student
{char name[20];
char num[20];
int score;
};
student stu[10000];//由于不确定n的大小,如果定义的数组太小,在提交的时候会出现段错误,故定义个比较大的数组
int i, max=-1,min=101,m,x;
cin>>i;
for (int n=0;n<i;n++)
{cin>>stu[n].name>>stu[n].num>>stu[n].score;
}
for(int n=0;n<i;n++)
{if(stu[n].score>max) {
max=stu[n].score;m=n;}//将最大分数的下标赋予m
if (stu[n].score<min) {
min=stu[n].score;x=n;}//将最小分数的下标赋予x
}
cout<<stu[m].name<<" "<<stu[m].num<<endl<<stu[x].name<<" "<<stu[x].num;
return 0;
}