作者 陶利
单位 合肥师范学院
本题要求定义并实现存储学生成绩信息的结构体数组(不超过30人),按姓名查找学生成绩信息(不超过3门课程),若找到则返回成绩,若没找到则返回Null。结构体可定义如下:
struct stu
{
char name[20];
int score[3];
};
输入格式:
第一行输入人数N(N<=30);
接下来输入N行学生姓名及成绩信息;格式为 “姓名 成绩1 成绩2 成绩3”,中间以空格分隔。
最后输入待查找的学生姓名。
输出格式:
输出查找到的学生姓名及其成绩,成绩以空格分隔;若没找到则返回Null;见输出样例。
输入样例:
3
Tracy 11 22 33
Anna 44 55 66
Susan 77 88 99
Anna
输出样例:
Anna: 44 55 66
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
栈限制
8192 KB
代码如下:
#include<stdio.h>
struct stu{
char name[20];
int score[3];
};
int main(){
int N;
scanf("%d",&N);
struct stu s[N];
for(int i=0;i<=N-1;i++){
scanf("%s %d %d %d",s[i].name,&s[i].score[0],
&s[i].score[1],&s[i].score[2]);
}
char Name[20];
scanf("%s",Name);
for(int i=0;i<=N-1;i++){
if(strcmp(s[i].name,Name)==0){
printf("%s: %d %d %d",s[i].name,s[i].score[0],
s[i].score[1],s[i].score[2]);
return 0;
}
}
printf("Null");
return 0;
}