读入 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
解题思路:
把数据读进来,按照成绩排序输出就行了。如果现在再做一次的话,我应该会用结构来做。
#include <stdio.h>
#define MAXS 14
int main() {
int n, i;
int max, maxid, min, minid;
if ( scanf("%d", &n)<1 ) printf("error");
char name[n][MAXS], stuid[n][MAXS];
int score[n];
for ( i=0; i<n; i++ ) {
if ( i==n-1 ) {
if ( scanf("%s", name[i])<1 ) printf("error");
if ( scanf("%s", stuid[i])<1 ) printf("error");
if ( scanf("%d", &score[i])<1 ) printf("error");
} else {
if ( scanf("%s", name[i])<1 ) printf("error");
if ( scanf("%s", stuid[i])<1 ) printf("error");
if ( scanf("%d\n", &score[i])<1 ) printf("error");
}
}
max = score[0], maxid = 0;
min = score[0], minid = 0;
for ( i=0; i<n; i++ ) {
if ( max < score[i] ) max=score[i], maxid=i;
if ( min > score[i] ) min=score[i], minid=i;
}
printf("%s %s\n", name[maxid], stuid[maxid]);
printf("%s %s", name[minid], stuid[minid]);
return 0;
}