PAT1004. 成绩排名 (20)

来源:互联网 发布:攻城略地手机挂机软件 编辑:程序博客网 时间:2024/06/06 04:15
读入n名学生的姓名、学号、成绩,分别输出成绩最高和成绩最低学生的姓名和学号。输入格式:每个测试输入包含1个测试用例,格式为  第1行:正整数n  第2行:第1个学生的姓名 学号 成绩  第3行:第2个学生的姓名 学号 成绩  ... ... ...  第n+1行:第n个学生的姓名 学号 成绩其中姓名和学号均为不超过10个字符的字符串,成绩为0100之间的一个整数,这里保证在一组测试用例中没有两个学生的成绩是相同的。输出格式:对每个测试用例输出2行,第1行是成绩最高学生的姓名和学号,第2行是成绩最低学生的姓名和学号,字符串间有1空格。输入样例:3Joe Math990112 89Mike CS991301 100Mary EE990830 95输出样例:Mike CS991301Joe 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; } 
原创粉丝点击