利用结构体+数组的操作,完成给5个人的超小型学生管理系统 具有增删改查功能
时间: 2024-03-26 08:40:55 浏览: 66
好的,下面是代码实现:
```
#include <stdio.h>
#include <string.h>
#define MAX_STUDENTS 5 // 最多存储的学生数量
// 学生结构体
struct Student {
char name[20]; // 学生姓名
int age; // 学生年龄
int id; // 学生编号
};
// 学生数组
struct Student students[MAX_STUDENTS];
// 学生数量
int count = 0;
// 查找学生
int findStudent(int id) {
for (int i = 0; i < count; i++) {
if (students[i].id == id) {
return i;
}
}
return -1;
}
// 添加学生
void addStudent() {
if (count >= MAX_STUDENTS) {
printf("学生数量已达到上限,无法添加新的学生!\n");
return;
}
struct Student student;
printf("请输入学生姓名:");
scanf("%s", student.name);
printf("请输入学生年龄:");
scanf("%d", &student.age);
student.id = count + 1;
students[count] = student;
count++;
printf("添加学生成功!\n");
}
// 删除学生
void deleteStudent() {
int id;
printf("请输入要删除的学生编号:");
scanf("%d", &id);
int index = findStudent(id);
if (index == -1) {
printf("找不到该学生,无法删除!\n");
return;
}
for (int i = index; i < count - 1; i++) {
students[i] = students[i + 1];
}
count--;
printf("删除学生成功!\n");
}
// 修改学生
void modifyStudent() {
int id;
printf("请输入要修改的学生编号:");
scanf("%d", &id);
int index = findStudent(id);
if (index == -1) {
printf("找不到该学生,无法修改!\n");
return;
}
printf("请输入学生姓名:");
scanf("%s", students[index].name);
printf("请输入学生年龄:");
scanf("%d", &students[index].age);
printf("修改学生成功!\n");
}
// 查询学生
void queryStudent() {
int id;
printf("请输入要查询的学生编号:");
scanf("%d", &id);
int index = findStudent(id);
if (index == -1) {
printf("找不到该学生!\n");
return;
}
struct Student student = students[index];
printf("学生编号:%d,学生姓名:%s,学生年龄:%d\n", student.id, student.name, student.age);
}
// 显示所有学生
void displayStudents() {
if (count == 0) {
printf("当前没有学生!\n");
return;
}
printf("学生编号\t学生姓名\t学生年龄\n");
for (int i = 0; i < count; i++) {
struct Student student = students[i];
printf("%d\t\t%s\t\t%d\n", student.id, student.name, student.age);
}
}
int main() {
while (1) {
printf("\n");
printf("超小型学生管理系统\n");
printf("1. 添加学生\n");
printf("2. 删除学生\n");
printf("3. 修改学生\n");
printf("4. 查询学生\n");
printf("5. 显示所有学生\n");
printf("6. 退出系统\n");
printf("请选择操作:");
int choice;
scanf("%d", &choice);
switch (choice) {
case 1:
addStudent();
break;
case 2:
deleteStudent();
break;
case 3:
modifyStudent();
break;
case 4:
queryStudent();
break;
case 5:
displayStudents();
break;
case 6:
printf("退出系统成功!\n");
return 0;
default:
printf("输入有误,请重新选择操作!\n");
break;
}
}
return 0;
}
```
这个超小型学生管理系统使用了结构体和数组来存储学生信息,并提供了增加、删除、修改、查询和显示所有学生等操作。其中,findStudent函数用于查找学生,addStudent函数用于添加学生,deleteStudent函数用于删除学生,modifyStudent函数用于修改学生,queryStudent函数用于查询学生,displayStudents函数用于显示所有学生。
阅读全文