大家好,又见面了,我是你们的朋友全栈君。
1004. 成绩排名 (20)
读入n名学生的姓名、学号、成绩,分别输出成绩最高和成绩最低学生的姓名和学号。
输入格式:每个测试输入包含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 maxsize 20
#define maxsize1 101
int main()
{
typedef struct arrange{
//学生结构
char name[maxsize];
char number[maxsize];
int grade;
}arrange;
int n=0,i=0;
arrange a[maxsize1];
int low=0,high=0;
scanf(“%d”,&n); //输入学生数目
for(i=0;i<n;++i){
//输入每个学生的姓名,学号,成绩
scanf(“%s %s %d”,&a[i].name,&a[i].number,&a[i].grade);
}
for(i=0;i<n;++i){
//遍历学生数组,得出最高分和最低分的学生
if(a[i].grade>a[high].grade){
high=i;
}
if(a[i].grade<a[low].grade){
low=i;
}
}
//输出最高分和最低分学生
printf(“%s %s\n”,a[high].name,a[high].number);
printf(“%s %s\n”,a[low].name,a[low].number);
return 0;
}
————————————-以上为我的c语言代码—————————————–
经验教训
1.学习了结构体的构造
typedef struct arrange{
语句A;
语句B;
}arrange;
arrange a[maxsize];
=struct arrange{
A;
B;
};
struct arrange a[maxsize];
2注意数组长度。
这个题目不难,但是我做的时候第一次三组数据只对了一个,后发现原因,是maxsize太小了,题中说明不超过10,但是我输入的是字符串,所以最后一位被’\0’占据,所以我只能最多输入9个字符,对于10个字符的测试数据自然不通过。将10修改为11(后来为了保险我就直接修改成20)后通过两个测试数据,第三个显示段错误,网上搜索发现依旧是数组溢出问题将maxsize1改为110,再次测试就全对了。
3在一行中连续输入字符串,以空格隔开
一开始我的输入是这样的
scanf(“%s”,&a[i].name);
scanf(“%s”,&a[i].name);
scanf(“%s”,&a[i].name);
达不到在一行中输入的目的
后来改成这样就可以了
scanf(“%s %s %d”,&a[i].name,&a[i].number,&a[i].grade);
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/136765.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...