用c语言写链式存储的学籍管理系统
时间: 2023-10-15 12:06:58 浏览: 83
基于C语言的学籍管理系统
5星 · 资源好评率100%
好的,下面是一个简单的用C语言实现的链式存储的学籍管理系统的代码。这个代码实现了学生的添加、删除、修改和查询等功能。
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
// 定义学生结构体
struct student {
char number[20];
char name[20];
char gender[5];
char birthday[20];
char class[20];
struct student *next;
};
// 定义全局变量,指向链表头部
struct student *head = NULL;
// 函数声明
void add_student();
void delete_student();
void modify_student();
void search_student();
void print_student(struct student *p);
int main() {
int choice;
while (1) {
// 显示菜单选项
printf("\n请选择操作:\n");
printf("1. 添加学生\n");
printf("2. 删除学生\n");
printf("3. 修改学生信息\n");
printf("4. 查询学生信息\n");
printf("5. 退出程序\n");
printf("请输入数字:");
scanf("%d", &choice);
switch (choice) {
case 1:
add_student();
break;
case 2:
delete_student();
break;
case 3:
modify_student();
break;
case 4:
search_student();
break;
case 5:
printf("\n谢谢使用,再见!\n");
exit(0);
default:
printf("\n输入有误,请重新输入!\n");
break;
}
}
}
// 添加学生
void add_student() {
struct student *p, *q;
p = (struct student *)malloc(sizeof(struct student));
if (p == NULL) {
printf("\n内存分配失败!\n");
return;
}
printf("\n请输入学生信息:\n");
printf("学号:");
scanf("%s", p->number);
printf("姓名:");
scanf("%s", p->name);
printf("性别:");
scanf("%s", p->gender);
printf("出生日期:");
scanf("%s", p->birthday);
printf("班级:");
scanf("%s", p->class);
p->next = NULL;
if (head == NULL) {
head = p;
} else {
q = head;
while (q->next != NULL) {
q = q->next;
}
q->next = p;
}
printf("\n添加成功!\n");
}
// 删除学生
void delete_student() {
char number[20];
struct student *p, *q;
if (head == NULL) {
printf("\n链表为空,无法删除!\n");
return;
}
printf("\n请输入要删除的学生学号:");
scanf("%s", number);
p = head;
q = NULL;
while (p != NULL && strcmp(p->number, number) != 0) {
q = p;
p = p->next;
}
if (p == NULL) {
printf("\n未找到该学生,无法删除!\n");
} else if (q == NULL) {
head = p->next;
free(p);
printf("\n删除成功!\n");
} else {
q->next = p->next;
free(p);
printf("\n删除成功!\n");
}
}
// 修改学生信息
void modify_student() {
char number[20];
struct student *p;
if (head == NULL) {
printf("\n链表为空,无法修改!\n");
return;
}
printf("\n请输入要修改的学生学号:");
scanf("%s", number);
p = head;
while (p != NULL && strcmp(p->number, number) != 0) {
p = p->next;
}
if (p == NULL) {
printf("\n未找到该学生,无法修改!\n");
} else {
printf("\n请输入修改后的学生信息:\n");
printf("学号(原值:%s):", p->number);
scanf("%s", p->number);
printf("姓名(原值:%s):", p->name);
scanf("%s", p->name);
printf("性别(原值:%s):", p->gender);
scanf("%s", p->gender);
printf("出生日期(原值:%s):", p->birthday);
scanf("%s", p->birthday);
printf("班级(原值:%s):", p->class);
scanf("%s", p->class);
printf("\n修改成功!\n");
}
}
// 查询学生信息
void search_student() {
char number[20];
struct student *p;
if (head == NULL) {
printf("\n链表为空,无法查询!\n");
return;
}
printf("\n请输入要查询的学生学号:");
scanf("%s", number);
p = head;
while (p != NULL && strcmp(p->number, number) != 0) {
p = p->next;
}
if (p == NULL) {
printf("\n未找到该学生,无法查询!\n");
} else {
printf("\n查询结果如下:\n");
print_student(p);
}
}
// 输出学生信息
void print_student(struct student *p) {
printf("学号:%s\n", p->number);
printf("姓名:%s\n", p->name);
printf("性别:%s\n", p->gender);
printf("出生日期:%s\n", p->birthday);
printf("班级:%s\n", p->class);
}
```
这个代码使用了链式存储的方式来实现学籍管理系统,每个学生节点包含学生的信息以及指向下一个学生节点的指针。在主函数中,通过不断地显示菜单选项,让用户选择要进行的操作。在各个操作函数中,使用链表的遍历、插入、删除等操作来实现各种功能。
阅读全文