学籍信息管理系统数据结构课程设计

时间: 2023-12-04 21:41:34 浏览: 47
学籍信息管理系统是一种常见的数据结构课程设计,通常使用结构体数组或链表结构来存储学生信息和管理员账号信息。以下是一个基于结构体数组的学籍信息管理系统的设计思路和实现方法: 1.定义学生信息结构体 ```c struct Student { char name[20]; // 学生姓名 char id[10]; // 学生学号 char gender[5]; // 学生性别 int age; // 学生年龄 float score; // 学生成绩 }; ``` 2.定义管理员账号结构体 ```c struct Admin { char username[20]; // 管理员用户名 char password[20]; // 管理员密码 }; ``` 3.定义学生信息数组和管理员账号数组 ```c struct Student students[100]; // 最多存储100个学生信息 struct Admin admins[10]; // 最多存储10个管理员账号信息 ``` 4.实现学生信息录入功能 ```c int studentCount = 0; // 当前学生数量 void addStudent() { struct Student student; printf("请输入学生姓名:"); scanf("%s", student.name); printf("请输入学生学号:"); scanf("%s", student.id); printf("请输入学生性别:"); scanf("%s", student.gender); printf("请输入学生年龄:"); scanf("%d", &student.age); printf("请输入学生成绩:"); scanf("%f", &student.score); students[studentCount++] = student; printf("学生信息录入成功!\n"); } ``` 5.实现学生信息查询功能 ```c void queryStudent() { char id[10]; printf("请输入要查询的学生学号:"); scanf("%s", id); for (int i = 0; i < studentCount; i++) { if (strcmp(students[i].id, id) == 0) { printf("姓名:%s\n", students[i].name); printf("学号:%s\n", students[i].id); printf("性别:%s\n", students[i].gender); printf("年龄:%d\n", students[i].age); printf("成绩:%f\n", students[i].score); return; } } printf("未找到该学生信息!\n"); } ``` 6.实现学生信息修改功能 ```c void modifyStudent() { char id[10]; printf("请输入要修改的学生学号:"); scanf("%s", id); for (int i = 0; i < studentCount; i++) { if (strcmp(students[i].id, id) == 0) { printf("请输入学生姓名:"); scanf("%s", students[i].name); printf("请输入学生性别:"); scanf("%s", students[i].gender); printf("请输入学生年龄:"); scanf("%d", &students[i].age); printf("请输入学生成绩:"); scanf("%f", &students[i].score); printf("学生信息修改成功!\n"); return; } } printf("未找到该学生信息!\n"); } ``` 7.实现学生信息删除功能 ```c void deleteStudent() { char id[10]; printf("请输入要删除的学生学号:"); scanf("%s", id); for (int i = 0; i < studentCount; i++) { if (strcmp(students[i].id, id) == 0) { for (int j = i; j < studentCount - 1; j++) { students[j] = students[j + 1]; } studentCount--; printf("学生信息删除成功!\n"); return; } } printf("未找到该学生信息!\n"); } ``` 8.实现学生信息输出功能 ```c void printStudent() { for (int i = 0; i < studentCount; i++) { printf("姓名:%s\n", students[i].name); printf("学号:%s\n", students[i].id); printf("性别:%s\n", students[i].gender); printf("年龄:%d\n", students[i].age); printf("成绩:%f\n", students[i].score); printf("\n"); } } ``` 9.实现管理员账号注册功能 ```c int adminCount = 0; // 当前管理员账号数量 void registerAdmin() { struct Admin admin; printf("请输入管理员用户名:"); scanf("%s", admin.username); printf("请输入管理员密码:"); scanf("%s", admin.password); admins[adminCount++] = admin; printf("管理员账号注册成功!\n"); } ``` 10.实现管理员账号登陆功能 ```c int currentAdminIndex = -1; // 当前登陆的管理员账号下标 void loginAdmin() { char username[20]; char password[20]; printf("请输入管理员用户名:"); scanf("%s", username); printf("请输入管理员密码:"); scanf("%s", password); for (int i = 0; i < adminCount; i++) { if (strcmp(admins[i].username, username) == 0 && strcmp(admins[i].password, password) == 0) { currentAdminIndex = i; printf("管理员账号登陆成功!\n"); return; } } printf("管理员账号登陆失败!\n"); } ``` 11.实现管理员账号查看功能 ```c void viewAdmin() { printf("管理员用户名:%s\n", admins[currentAdminIndex].username); printf("管理员密码:%s\n", admins[currentAdminIndex].password); } ``` 12.实现管理员账号删除功能 ```c void deleteAdmin() { char username[20]; printf("请输入要删除的管理员用户名:"); scanf("%s", username); for (int i = 0; i < adminCount; i++) { if (strcmp(admins[i].username, username) == 0) { for (int j = i; j < adminCount - 1; j++) { admins[j] = admins[j + 1]; } adminCount--; printf("管理员账号删除成功!\n"); return; } } printf("未找到该管理员账号!\n"); } ``` 以上是一个基于结构体数组的学籍信息管理系统的设计思路和实现方法。如果使用链表结构存储学生信息和管理员账号信息,可以更加灵活地实现增删改查等功能。如果您有其他问题或需要更详细的代码实现,请随时提出。

相关推荐

最新推荐

recommend-type

数据结构课程设计 学籍管理系统

为学生管理人员编写一个学生信息管理查询软件。 【基本要求】 1) 程序设计要求: ①采用交互工作方式,设计功能菜单; ②建立数据文件,数据包含学生的自然信息和成绩信息(设计几门课以及总成绩); ③对如下关键字...
recommend-type

VB课程设计之学生信息管理系统

4.1.2 创建学生信息管理系统的主窗体 18 4.1.3 创建主窗体的菜单 20 4.1.4 创建公用模块 20 4.2 系统用户管理模块的创建 21 4.2.1 用户登录窗体的创建 21 4.2.2 添加用户窗体的创建 23 4.2.3 修改用户密码窗体的创建...
recommend-type

学生学籍管理信息系统课程设计报告

管理信息系统课程设计报告 ---XXX管理信息系统设计 学院:工商管理学院 班级: 姓名: 学号: 指导教师: 职称:讲师 时间:2009年6月22日到6月26日 目 录 一 绪论 1.1项目背景……………………………………...
recommend-type

会议信息管理系统详细设计

在系统中包括以下功能:系统管理、学籍信息管理、课程信息管 理、成绩信息管理、帮助。分为以下几个模块 主窗体 标 题 名 称 系统管理 sysMenu ……用户管理 Control ……退出系统 Exit 学籍管理 sInfo ...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

spring添加xml配置文件

1. 创建一个新的Spring配置文件,例如"applicationContext.xml"。 2. 在文件头部添加XML命名空间和schema定义,如下所示: ``` <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依