大一C语言作业题目1

目录

字符串和字符数组?

%s

found的变化:


7-1 学生成绩录入及查询

学生成绩表中,一名学生的信息包含如下信息:
学号(11位)、姓名、数学成绩、英语成绩、程序设计成绩、物理成绩。

本题要求编写程序,录入N条学生的信息,并且按查询要求显示学生成绩等信息。

输入格式:

输入在第一行给出正整数N(N<=10);随后N行,每行按格式:

复制代码
学号 姓名 数学成绩 英语成绩 程序设计成绩 物理成绩

给出一名学生的信息。
其中学号是11位数字;姓名是不超过10个字符、不包含空格的非空字符串;成绩是<=100的非负整数;

在学生信息输入完成后,给出要查询的姓名。

输出格式:

对查询的姓名的每一名学生,在一行中按照如下格式输出:

复制代码
学号  姓名 数学成绩 英语成绩 程序设计成绩 物理成绩

如果有相同姓名的同学,输出全部同学的信息,每名同学一行;
如果要查询的学生不存在,则输出:

复制代码
Not Found!

输入样例:

在这里给出一组输入。例如:

复制代码
4
20201003012 LiWen 68 90 78 86
20201003012 HeHua 91 88 80 82
20201002121 WangFang 78 78 82 90
20201002112 ZhengYi 56 83 77 80
ZhengYi

输出样例:

在这里给出相应的输出。例如:

复制代码
20201002112 ZhengYi 56 83 77 80

cs 复制代码
#include <stdio.h>
#include <string.h>

struct Student {
    char id[12];
    char name[11];
    int math;
    int english;
    int programming;
    int physics;
};

int main() {
    int N;
    scanf("%d", &N);
    struct Student students[N];

    for (int i = 0; i < N; i++) {
        scanf("%s %s %d %d %d %d", students[i].id, students[i].name, &students[i].math, &students[i].english, &students[i].programming, &students[i].physics);
    }

    char queryName[11];
    scanf("%s", queryName);

    int found = 0;
    for (int i = 0; i < N; i++) {
        if (strcmp(students[i].name, queryName) == 0) {
            printf("%s %s %d %d %d %d\n", students[i].id, students[i].name, students[i].math, students[i].english, students[i].programming, students[i].physics);
            found = 1;
        }
    }

    if (!found) {
        printf("Not Found!\n");
    }

    return 0;
}

注意点:

字符串和字符数组?

字符数组和字符串的区别,C语言字符数组和字符串区别详解_字符数组和字符串数组的区别-CSDN博客
char name [12]

因此,以上是字符串。如果不标注是[12],就会默认为1。


struct Student students[N];

这是创建一个数量为N的student类型的students。

for (int i = 0; i < N; i++) {
scanf("%s %s %d %d %d %d", students[i].id, students[i].name, &students[i].math, &students[i].english, &students[i].programming, &students[i].physics);
}


%s

在这里,因为id和name都是字符串,而且是数组,就只需要写%s


found的变化:

总结起来,found 变量的变化如下:

  • 初始化:found 被设置为0,表示尚未找到匹配的学生。

  • 遍历学生数组时,如果找到与查询姓名相同的学生,found 的值会被更新为1。

  • 在遍历结束后,检查 found 的值。如果 found 为0,输出 "Not Found!";否则,已经找到了匹配的学生,并在找到时已经输出了该学生的相关信息。


    如果有相同姓名的同学,输出全部同学的信息,每名同学一行;

这句话的意思不是说如果有相同姓名的同学,就把所有包括其他姓名的同学的信息都输出来,而是说输出和访问者输入名字相同的人的所有信息

相关推荐
hie9889412 分钟前
MATLAB锂离子电池伪二维(P2D)模型实现
人工智能·算法·matlab
杰克尼23 分钟前
BM5 合并k个已排序的链表
数据结构·算法·链表
大苏打seven1 小时前
Docker学习笔记:Docker网络
笔记·学习·docker
.30-06Springfield1 小时前
决策树(Decision tree)算法详解(ID3、C4.5、CART)
人工智能·python·算法·决策树·机器学习
我不是哆啦A梦1 小时前
破解风电运维“百模大战”困局,机械版ChatGPT诞生?
运维·人工智能·python·算法·chatgpt
xiaolang_8616_wjl1 小时前
c++文字游戏_闯关打怪
开发语言·数据结构·c++·算法·c++20
small_wh1te_coder1 小时前
硬件嵌入式学习路线大总结(一):C语言与linux。内功心法——从入门到精通,彻底打通你的任督二脉!
linux·c语言·汇编·嵌入式硬件·算法·c
hqxstudying2 小时前
Java创建型模式---单例模式
java·数据结构·设计模式·代码规范
挺菜的2 小时前
【算法刷题记录(简单题)002】字符串字符匹配(java代码实现)
java·开发语言·算法
sun0077002 小时前
数据结构——栈的讲解(超详细)
数据结构