PTA 结构体数组查找:根据姓名查询成绩

作者 陶利

单位 合肥师范学院

本题要求定义并实现存储学生成绩信息的结构体数组(不超过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;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值