【挑战开发100个项目 | 1. C语言学生管理系统】

本项目是一个简易的学生信息管理系统,用户可以通过命令行界面完成学生信息的增加、删除、修改、查询、排序和列表展示等功能。数据以txt文件形式存储,实现了数据持久化。项目采用模块化设计,具有较好的可读性和扩展性。适用于初学者学习c语言,也适用于高校学生课程设计,毕业设计参考。

一,开发环境需求

  • 操作系统 :windows, linux

  • 开发环境工具 :qt ,vscode, visual studio

  • 技术要求

    • 语言: C
    • 数据结构: 链表
    • 文件操作: 文件读写操作

二,功能说明

在这里插入图片描述

三,功能实现

  1. 录入学生信息
void addStudent(StudentList *list) {Student newStudent;printf("请输入学生信息:\n");printf("学号: ");scanf("%d", &(newStudent.id));while(getchar() != '\n');printf("姓名: ");fgets(newStudent.name, sizeof(newStudent.name), stdin);newStudent.name[strlen(newStudent.name)-1] = '\0'; // remove the newlineprintf("年龄: ");scanf("%d", &(newStudent.age));while(getchar() != '\n');printf("性别: ");fgets(newStudent.gender, sizeof(newStudent.gender), stdin);newStudent.gender[strlen(newStudent.gender)-1] = '\0';printf("专业: ");fgets(newStudent.major, sizeof(newStudent.major), stdin);newStudent.major[strlen(newStudent.major)-1] = '\0';printf("班级: ");fgets(newStudent.class_name, sizeof(newStudent.class_name), stdin);newStudent.class_name[strlen(newStudent.class_name)-1] = '\0';printf("成绩: ");scanf("%f", &(newStudent.score));// add the new student to the listStudentNode *newNode = (StudentNode*)malloc(sizeof(StudentNode));newNode->data = newStudent;newNode->next = list->head;list->head = newNode;list->count++;printf("学生信息已添加成功!\n");
}

此函数用于添加学生信息。

  1. 删除学生信息
void deleteStudent(StudentList *list) {int id;printf("请输入要删除的学生的学号: ");scanf("%d", &id);StudentNode *current = list->head;StudentNode *previous = NULL;while (current != NULL) {if (current->data.id == id) {if (previous == NULL) {list->head = current->next;} else {previous->next = current->next;}free(current);list->count--;printf("学生信息已删除。\n");return;}previous = current;current = current->next;}printf("未找到该学生的信息。\n");
}

此函数用于删除指定学生信息。

3.s 修改学生信息

void modifyStudent(StudentList *list) {int id;printf("请输入要修改的学生的学号: ");scanf("%d", &id);StudentNode *current = list->head;while (current != NULL) {if (current->data.id == id) {printf("请输入新的学生信息:\n");printf("姓名: ");while(getchar() != '\n'); // clear bufferfgets(current->data.name, sizeof(current->data.name), stdin);current->data.name[strlen(current->data.name)-1] = '\0'; // remove newlineprintf("年龄: ");scanf("%d", &(current->data.age));printf("性别: ");while(getchar() != '\n');fgets(current->data.gender, sizeof(current->data.gender), stdin);current->data.gender[strlen(current->data.gender)-1] = '\0';printf("专业: ");while(getchar() != '\n');fgets(current->data.major, sizeof(current->data.major), stdin);current->data.major[strlen(current->data.major)-1] = '\0';printf("班级: ");while(getchar() != '\n');fgets(current->data.class_name, sizeof(current->data.class_name), stdin);current->data.class_name[strlen(current->data.class_name)-1] = '\0';printf("成绩: ");scanf("%f", &(current->data.score));printf("学生信息已修改。\n");return;}current = current->next;}printf("未找到该学生的信息。\n");
}

此函数用于修改指定学生信息。

  1. 查询学生信息
void queryStudent(const StudentList *list) {int id;printf("请输入要查询的学生的学号: ");scanf("%d", &id);StudentNode *current = list->head;while (current != NULL) {if (current->data.id == id) {printf("学号: %d\n", current->data.id);printf("姓名: %s\n", current->data.name);printf("年龄: %d\n", current->data.age);printf("性别: %s\n", current->data.gender);printf("专业: %s\n", current->data.major);printf("班级: %s\n", current->data.class_name);printf("成绩: %.2f\n", current->data.score);return;}current = current->next;}printf("未找到该学生的信息。\n");
}

此函数用于查询指定学生信息。

  1. 对学生信息排序
// 排序学生信息(这里以学号为例,升序排列)
void sortStudents(StudentList *list) {// 使用冒泡排序算法if (list->count < 2) return;StudentNode *i, *j;for (i = list->head; i->next != NULL; i = i->next) {for (j = list->head; j->next != NULL; j = j->next) {if (j->data.id > j->next->data.id) {// 交换数据Student temp = j->data;j->data = j->next->data;j->next->data = temp;}}}printf("学生信息已排序。\n");
}

此函数用于对学生信息进行排序。

  1. 列出所有学生信息
void displayAllStudents(const StudentList *list) {if (!list->head) {printf("没有学生信息可供显示。\n");return;}printf("学号   姓名       年龄 性别 专业                  班级       成绩\n");printf("-----------------------------------------------------------------\n");StudentNode *current = list->head;while (current != NULL) {printf("%-6d %-10s %-4d %-4s %-20s %-10s %.2f\n",current->data.id, current->data.name, current->data.age,current->data.gender, current->data.major, current->data.class_name,current->data.score);current = current->next;}printf("-----------------------------------------------------------------\n");
}

此函数用于显示所有学生的信息。

四,效果图

后续截图添加

五,源码

代码已开源,可访问gitee下载。

六,总结

本项目是一个简单的学生信息管理系统,通过命令行界面与用户交互。主要实现了学生信息的增、删、查、改等功能。项目中主要使用C语言进行开发,并使用链表作为主要数据结构。经过严格的测试和修正,现在可以正常运行并满足基本的需求。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/88416.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JDK21新特性 有序集合

有序集合 描述常用有序集合体系LinkedHashMapLinkedHashSetLinkedBlockingDequeArrayDeque 三级目录 描述 Java集合体系中&#xff0c;原来就有有序集合实现&#xff0c;但是没有规范支持有序操作的接口。 JDK21 新增了两个接口 SequencedCollection&#xff0c;SequencedMa…

知识图谱:信息抽取简易流程

目录 一、标注训练数据 二、训练数据模型 三、实现NER 一、标注训练数据 使用工具:Brat ## BRAT安装 0、安装条件 (1)运行于Linux系统 (2)brat(v1.3p1)仅支持python2版本运行使用,否则会报错 File "standalone.py", line 257except SystemExit, sts:^Syn…

HTML+VUE+element-ui通过点击不同按钮展现不同页面

完整源码可以私聊我&#xff0c;需要一点点费用~ 页面展示 方案一 方案二 代码解释 方案一&#xff1a;使用v-show 这种方案只适合有两种页面 现在form表单中设置好要展现的页面名&#xff08;此处的url没有作用不用管&#xff09; 通过一个两个for循环分别将form表单填入…

PWN环境搭建

虚拟机Ubuntu安装 工具&#xff1a;Vmware 16 以及 Ubuntu 18或20 来源&#xff1a;清华大学开源软件镜像站 | Tsinghua Open Source Mirror 虚拟机安装流程 安装很简单&#xff0c;按照提示一步步来即可 处理器可以多给一些&#xff0c;我给了8个&#xff0c;内核数量不…

004:vue使用relation-graph实现关系图谱

文章目录 1. 效果2. relation-graph简介3. 安装及使用4. 其他更多示例 1. 效果 2. relation-graph简介 这是一个Vue关系图谱组件&#xff0c;可以展示如组织机构图谱、股权架构图谱、集团关系图谱等知识图谱&#xff0c;可提供多种图谱布局&#xff0c;包括树状布局、中心布局…

ChatGPT推出全新功能,引发人工智能合成声音担忧|百能云芯

人工智能AI科技企业OpenAI公司25日宣布&#xff0c;其聊天应用程序ChatGPT如今具备「看、听、说」能力&#xff0c;至少能够理解口语、用合成语音回应并且处理图像&#xff1b;但专家忧心&#xff0c;以假乱真与深度伪造的乱象可能变本加厉。 国家广播公司新闻网(NBC News)报导…

全新UI基于Thinkphp的最新自助打印系统/云打印小程序源码/附教程

这是一款全新的基于Thinkphp的最新自助打印系统&#xff0c;最新UI界面设计的云打印小程序源码&#xff0c;带有简单的教程。 下载地址&#xff1a;https://bbs.csdn.net/topics/617324130

简述ceph文件储存系统

Ceph 是一个统一的分布式存储系统和共享机制&#xff0c;它定义了数据如何存储在一个或多个节点上并呈现给其他机器以供文件访问。 Ceph特点 高性能 a. 摒弃了传统的集中式存储元数据寻址的方案&#xff0c;采用CRUSH算法&#xff0c;数据分布均衡&#xff0c;并行度高。 b.考…

WSL2编译安卓11源码,,刷入pixel设备,并使用asfp查看源码

目录 WSL2编译安卓11源码,&#xff0c;刷入pixel设备源码下载驱动下载编译刷机源码导入Android Studio for platformADB调试 WSL2编译安卓11源码,&#xff0c;刷入pixel设备 aosp编译完成后&#xff0c;刷入手机其实非常简单&#xff0c;但是使用wsl有一个问题&#xff0c;就是…

crypto:变异凯撒

题目 下载题目所给的压缩包后解压得到文本提示 由题目名可知为凯撒密码 根据提示格式为flag{}&#xff0c;所以猜测前四个字符原文为flag 先来推测一下偏移量 a->f 偏移量为-5&#xff0c;按道理来说每个字符的偏移量都是一样的&#xff0c;但是对照过后发现后面的字符对…

Java面向对象高级

文章目录 面向对象高级Object类的常用方法常用方法一&#xff08;面向对象阶段&#xff09;** 和 equals 的区别** 关键字native**单例设计模式&#xff08;Singleton&#xff09;**前情回顾&#xff08;学习基础&#xff09;静态修饰符Static设计模式概念开发步骤**两种实现方…

springboot集成quartz并实现定时任务管理

依赖&#xff1a; <quartz.version>2.3.0</quartz.version><dependency><groupId>org.quartz-scheduler</groupId><artifactId>quartz</artifactId><version>${quartz.version}</version><exclusions><exclus…

“的修“报修工单管理系统有哪些功能和作用?

“的修"报修工单管理系统是基于微信平台的&#xff0c;无需下载和安装&#xff0c;只需扫码即可使用。它是一个维保过程管控的理想解决方案&#xff0c;适用于企业、学校、医院、物业等单位需要设备维保的场景。“的修"报修小程序具有独立部署和可控的数据安全性&…

手把手教你实现:将后端SpringBoot项目部署到华为云服务器上

前言 前提&#xff1a;有一个后端项目&#xff0c;项目能够运行在本地&#xff0c;可以通过本地访问&#xff08;localhost&#xff09; 如果没有可以看这篇&#xff1a;一个基于SpringBoot的后端项目 注册华为云账号 华为云官网 购买云服务器 产品 -> 华为云耀云服务器…

【数据结构-树】哈夫曼树

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kuan 的首页,持续学…

图片编辑小程序源码/拼图小程序源码

图片编辑小程序源码&#xff0c;拼图小程序源码。全能、便捷的图片编辑工具。实现了图片裁剪、添加文字、涂鸦、拼长图、拼相框等图片编辑功能&#xff0c;另外还有一个简易的表情包制作功能。 主要有以下几个功能&#xff1a;图片裁剪、添加文字、涂鸦功能、拼长图、拼相框、表…

mybati缓存了解

title: “mybati缓存了解” createTime: 2021-12-08T12:19:5708:00 updateTime: 2021-12-08T12:19:5708:00 draft: false author: “ggball” tags: [“mybatis”] categories: [“java”] description: “mybati缓存了解” mybatis的缓存 首先来看下mybatis对缓存的规范&…

Ingress Controller

什么是 Ingress Controller &#xff1f; 在云原生生态中&#xff0c;通常来讲&#xff0c;入口控制器( Ingress Controller )是 Kubernetes 中的一个关键组件&#xff0c;用于管理入口资源对象。 Ingress 资源对象用于定义来自外网的 HTTP 和 HTTPS 规则&#xff0c;以控制进…

el-image 和 el-table冲突层级冲突问题

其中原理&#xff0c;很多博客已经所过了&#xff0c;table组件中使用图片&#xff0c;会出现层级过低问题&#xff0c; 网上大部分解决方式是 使用穿透 // 单元格样式 ::v-deep(.el-table__cell) {position: static !important; }我在此不推荐这种解决方式&#xff0c;原因&a…

Leetcode228. 汇总区间

力扣&#xff08;LeetCode&#xff09;官网 - 全球极客挚爱的技术成长平台 给定一个 无重复元素 的 有序 整数数组 nums 。 返回 恰好覆盖数组中所有数字 的 最小有序 区间范围列表 。也就是说&#xff0c;nums 的每个元素都恰好被某个区间范围所覆盖&#xff0c;并且不存在属…