学籍信息管理系统数据结构课程设计
时间: 2023-12-04 12:41:34 浏览: 155
学生学籍管理系统(数据结构课程设计报告)
学籍信息管理系统是一种常见的数据结构课程设计,通常使用结构体数组或链表结构来存储学生信息和管理员账号信息。以下是一个基于结构体数组的学籍信息管理系统的设计思路和实现方法:
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");
}
```
以上是一个基于结构体数组的学籍信息管理系统的设计思路和实现方法。如果使用链表结构存储学生信息和管理员账号信息,可以更加灵活地实现增删改查等功能。如果您有其他问题或需要更详细的代码实现,请随时提出。
阅读全文