讀入 n(>0)名學生的姓名、學號、成績,分別輸出成績最高和成績最低學生的姓名和學號。 輸入格式: 每個測試輸入包含 1 個測試用例,格式為 其中姓名和學號均為不超過 10 個字元的字元串,成績為 0 到 100 之間的一個整數,這裡保證在一組測試用例中沒有兩個學生的成績是相同的。 輸出格式: 對每 ...
讀入 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\n",max.name,max.num);
26 printf("%s %s\n",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",&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\n",max.name,max.num); 28 printf("%s %s\n",min.name,min.num); 29 return 0; 30 }