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


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

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

相关推荐
一条大祥脚4 分钟前
26.1.26 扫描线+数论|因子反演+子序列计数|树套树优化最短路
数据结构·算法
m0_561359677 分钟前
基于C++的机器学习库开发
开发语言·c++·算法
星空露珠14 分钟前
速算24点所有题库公式
开发语言·数据库·算法·游戏·lua
2401_8324027515 分钟前
C++中的类型擦除技术
开发语言·c++·算法
无聊的小坏坏18 分钟前
实习笔记:用 /etc/crontab 实现定期数据/日志清理
笔记·实习日记
香芋Yu19 分钟前
【机器学习教程】第04章 指数族分布
人工智能·笔记·机器学习
努力学习的小廉23 分钟前
我爱学算法之—— 递归回溯综合(二)
开发语言·算法
sheji526124 分钟前
JSP基于信息安全的读书网站79f9s--程序+源码+数据库+调试部署+开发环境
java·开发语言·数据库·算法
2301_7634724625 分钟前
C++网络编程(Boost.Asio)
开发语言·c++·算法
依依yyy30 分钟前
沪深300指数收益率波动性分析与预测——基于ARMA-GARCH模型
人工智能·算法·机器学习