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
思路:用二个二维数组来存放姓名,和学号,用一个一维数组来放分数。二个并列的if语句分别进行判断刚输入进来的分数是否为最大的或者是最小的,因为2个并列的if语句,就算满足第一个if语句,第二个if语句也会执行。(读者如果感觉2个if有点多余,可以接着往下看,其实不多余的。)
方案一:
#include<stdio.h>
#include<string.h>
int main(){
int n,min=0,max=100,signmax=0,signmin=0,c[100];
char a[100][11],b[100][11];//用二维数组来存放记录
scanf("%d",&n);
for(int i=0;i<n;i++){//实现循环输入
scanf("%s",a[i]);
scanf("%s",b[i]);
scanf("%d",&c[i]);
//进来一个成绩,最大和最小都要比较
if(c[i]<max){
max=c[i];//比最大值小,就把他赋值给max,说明max出来的数是最小的。
signmin=i;
}
if(c[i]>min){
min=c[i];比最小值大,就把他赋值给min,说明min出来的数是最大的。
signmax=i;
}
}
printf("%s %s\n",a[signmax],b[signmax]);//成绩最高学生的记录
printf("%s %s\n",a[signmin],b[signmin]);//成绩最低学生的记录
return 0;
}
//或者用下面的结构
if(){
}else{
if(){//这里必须再判断一下,因为上面的if成立只能说明,
//他只是比最小的大,但是他不一定是最大的,所以还要进行一次if判断.
//所以不如干脆就直接用2个if语句分别进行2次判断
}
}
方案二:
#include<stdio.h>
#include<string.h>
int main(){
int n,min=0,max=100,signmax=0,signmin=0,c[100];//注意理解最大值和最小值的赋值,最大值是0,最小值是100
char a[100][11],b[100][11];//用二维数组来存放记录
scanf("%d",&n);
for(int i=0;i<n;i++){//实现循环输入
scanf("%s",a[i]);
scanf("%s",b[i]);
scanf("%d",&c[i]);
//进来一个成绩,最大和最小都要比较
if(c[i]<max){
max=c[i];//比最大值小,就把他赋值给max,说明max出来的数是最小的。
signmin=i;
}
else{
if(c[i]>min){
min=c[i];比最小值大,就把他赋值给min,说明min出来的数是最大的。
signmax=i;
}
}
}
printf("%s %s\n",a[signmax],b[signmax]);//成绩最高学生的记录
printf("%s %s\n",a[signmin],b[signmin]);//成绩最低学生的记录
return 0;
}