大一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!";否则,已经找到了匹配的学生,并在找到时已经输出了该学生的相关信息。


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

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

相关推荐
叶小鸡1 小时前
Java 篇-项目实战-苍穹外卖-笔记汇总
java·开发语言·笔记
昵称小白2 小时前
复杂度分析方法
算法
科研前沿2 小时前
2026 数字孪生前沿科技:全景迭代报告 —— 镜像视界生成式孪生(Generative DT)技术白皮书
大数据·人工智能·科技·算法·音视频·空间计算
sakiko_3 小时前
UIKit学习笔记4-使用UITableView制作滚动视图
笔记·学习·ios·swift·uikit
leo__5204 小时前
IEC 104 协议 C 语言实现
c语言·数据库
晓梦林4 小时前
MAZESEC-X1靶场学习笔记
笔记·学习
学涯乐码堂主4 小时前
有趣的“打擂台算法”
c++·算法·青少年编程·gesp
切糕师学AI4 小时前
环形缓冲区(Ring Buffer / Circular Buffer)详解:原理、优势、应用与高性能实现
数据结构·环形缓冲区
Tutankaaa4 小时前
知识竞赛题库设计全攻略
人工智能·算法
WolfGang0073215 小时前
代码随想录算法训练营 Day50 | 图论 part08
数据结构·算法·图论