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


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

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

相关推荐
byte轻骑兵29 分钟前
【0x0012】HCI_Delete_Stored_Link_Key命令详解
c语言·蓝牙·通信协议·hci
xiaocao_102331 分钟前
手机备忘录:安全存储与管理个人笔记的理想选择
笔记·安全·智能手机
索然无味io35 分钟前
XML外部实体注入--漏洞利用
xml·前端·笔记·学习·web安全·网络安全·php
王磊鑫1 小时前
Java入门笔记(1)
java·开发语言·笔记
安冬的码畜日常1 小时前
【Vim Masterclass 笔记22】S09L40 + L41:同步练习11:Vim 的配置与 vimrc 文件的相关操作(含点评课内容)
笔记·vim·vim配置·vim同步练习·vim options·vim option-list
Bunury2 小时前
组件封装-List
javascript·数据结构·list
Joeysoda2 小时前
Java数据结构 (从0构建链表(LinkedList))
java·linux·开发语言·数据结构·windows·链表·1024程序员节
天乐敲代码2 小时前
JAVASE入门九脚-集合框架ArrayList,LinkedList,HashSet,TreeSet,迭代
java·开发语言·算法
比特在路上2 小时前
ListOJ14:环形链表II(寻找环的入口点)
数据结构·链表
十年一梦实验室2 小时前
【Eigen教程】矩阵、数组和向量类(二)
线性代数·算法·矩阵