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


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

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

相关推荐
式5162 小时前
线性代数(七)主变量与特解
线性代数·算法
业精于勤的牙8 小时前
浅谈:算法中的斐波那契数(二)
算法·职场和发展
2301_764441338 小时前
Aella Science Dataset Explorer 部署教程笔记
笔记·python·全文检索
不穿格子的程序员8 小时前
从零开始写算法——链表篇4:删除链表的倒数第 N 个结点 + 两两交换链表中的节点
数据结构·算法·链表
liuyao_xianhui8 小时前
寻找峰值--优选算法(二分查找法)
算法
dragoooon348 小时前
[hot100 NO.19~24]
数据结构·算法
派大鑫wink9 小时前
【Java 学习日记】开篇:以日记为舟,渡 Java 进阶之海
java·笔记·程序人生·学习方法
电子硬件笔记9 小时前
Python语言编程导论第七章 数据结构
开发语言·数据结构·python
南棱笑笑生9 小时前
20251217给飞凌OK3588-C开发板适配Rockchip原厂的Buildroot【linux-5.10】后调通ov5645【只能预览】
linux·c语言·开发语言·rockchip
Tony_yitao10 小时前
15.华为OD机考 - 执行任务赚积分
数据结构·算法·华为od·algorithm