读入 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
1 #include<stdio.h>
2 #include<math.h>
3 #include<stdlib.h>
4 #include<string.h>
5 struct student
6 {
7 int grade;
8 char name[11],num[11];
9 }
10 s,max,min;
11 int main()
12 {
13 int n;
14 max.grade=-1;
15 min.grade=101;
16 scanf("%d",&n);
17 while(n--)
18 {
19 scanf("%s %s %d",&s.name,&s.num,&s.grade);
20 if(s.grade>max.grade)
21 max=s;
22 if(s.grade<min.grade)
23 min=s;
24 }
25 printf("%s %s
",max.name,max.num);
26 printf("%s %s
",min.name,min.num);
27 return 0;
28 }
补充另一种写法,推荐大家用这种,好理解......
1 #include<stdio.h> 2 #include<math.h> 3 #include<string.h> 4 #include<stdlib.h> 5 typedef struct student 6 { 7 char name[11]; 8 char num[11]; 9 int grade; 10 }St; 11 int main() 12 { 13 int N; 14 scanf("%d ",&N); 15 St sum[N]; 16 St max,min; 17 max.grade=-999; 18 min.grade=999; 19 for(int i=0;i<N;i++) 20 { 21 scanf("%s %s %d",sum[i].name,sum[i].num,&sum[i].grade); 22 if(sum[i].grade>max.grade) 23 max=sum[i]; 24 if(sum[i].grade<min.grade) 25 min=sum[i]; 26 } 27 printf("%s %s ",max.name,max.num); 28 printf("%s %s ",min.name,min.num); 29 return 0; 30 }