读入 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
方案一:因为是 储存 多个字符串与成绩
可以通过定义数组,字符串用二维数组储存
通过统一的一个数组中的位置变量,来确定。
int n ;
char name[1010][15], id[1010][15] ;
int score[1010] ;
scanf ("%d", &n) ;
for (int x=0; x<n; x++) {
scanf ("%s %s %d", &name[x], &id[x], &score[x]) ;
}//这种利用' '来区别储存的数组
但是,题目中并未给出明确的数组长度,需要根据输入来判断,故不适合此方法。
方案二:利用结构体。(本题是非常经典的结构体应用)
结构体基础知识1
结构体基础知识2
下面将使用这种方案
#include<stdio.h>
struct student {
char name[11];
char ID[11];
int score;
};
struct student min = { "","",100 }, max = { "","",0 };
int main() {
int i;
scanf("%d", &i);
while (i--) {
struct student the;
scanf("%s%s%d", the.name, the.ID, &the.score);
if (the.score >max.score)
max = the;
if (the.score < min.score)
min = the;
}
printf("%s %s\n", max.name, max.ID);
printf("%s %s\n", min.name, min.ID);
}
补充:对于一些比较的问题
有两种解决思路:
1.全部储存完,然后一个一个比较,数组储存并遍历便是此种方法
2.储存一个,比较一个,此题中便是用这个,利用getchar求和的方法也属于此,往往减少代码量,但功能较为单一。
补充一个学习中的小点:scanf读入字符串(%s),可以以空格分隔,但是读入单个字符(%c)的时候,则需要两个%c之间加入需要跳过的字符。