C语言学生管理系统结构体数组
时间: 2023-08-25 22:07:57 浏览: 106
一个简单的 C 语言学生管理系统可以使用结构体数组来实现。下面是一个简单的示例代码:
```c
#include <stdio.h>
#include <string.h>
#define MAX_STUDENTS 100
struct student {
int id;
char name[50];
double score;
};
int main() {
struct student students[MAX_STUDENTS];
int num_students = 0;
while (1) {
printf("请选择操作:\n");
printf("1. 添加学生\n");
printf("2. 删除学生\n");
printf("3. 修改学生信息\n");
printf("4. 查询学生信息\n");
printf("5. 退出\n");
int choice;
scanf("%d", &choice);
switch (choice) {
case 1:
printf("请输入学生ID:");
scanf("%d", &students[num_students].id);
printf("请输入学生姓名:");
scanf("%s", students[num_students].name);
printf("请输入学生成绩:");
scanf("%lf", &students[num_students].score);
num_students++;
printf("添加成功!\n");
break;
case 2:
printf("请输入要删除的学生ID:");
int id_to_remove;
scanf("%d", &id_to_remove);
for (int i = 0; i < num_students; i++) {
if (students[i].id == id_to_remove) {
// 将该学生后面的所有学生往前移动一位
for (int j = i; j < num_students - 1; j++) {
students[j] = students[j + 1];
}
num_students--;
printf("删除成功!\n");
break;
}
}
break;
case 3:
printf("请输入要修改的学生ID:");
int id_to_modify;
scanf("%d", &id_to_modify);
for (int i = 0; i < num_students; i++) {
if (students[i].id == id_to_modify) {
printf("请输入学生姓名:");
scanf("%s", students[i].name);
printf("请输入学生成绩:");
scanf("%lf", &students[i].score);
printf("修改成功!\n");
break;
}
}
break;
case 4:
printf("请输入要查询的学生ID:");
int id_to_query;
scanf("%d", &id_to_query);
for (int i = 0; i < num_students; i++) {
if (students[i].id == id_to_query) {
printf("学生ID:%d\n", students[i].id);
printf("学生姓名:%s\n", students[i].name);
printf("学生成绩:%.2lf\n", students[i].score);
break;
}
}
break;
case 5:
printf("谢谢使用!\n");
return 0;
default:
printf("无效的选择,请重新输入!\n");
break;
}
}
}
```
在这个示例程序中,我们定义了一个结构体 `student` 来表示学生,包括学生的 ID、姓名和成绩三个属性。我们使用结构体数组 `students` 来存储所有学生的信息。在主函数中,我们通过一个循环来接收用户的输入,并根据不同的选择来进行相应的操作。当用户选择添加学生时,我们先接收学生的 ID、姓名和成绩,并将其存储到结构体数组中。当用户选择删除学生时,我们接收要删除的学生的 ID,然后在结构体数组中查找该学生的位置,并将该学生后面的所有学生往前移动一位,最后将学生总数减一。当用户选择修改学生信息时,我们接收要修改的学生的 ID,然后在结构体数组中查找该学生的位置,并接收新的姓名和成绩并修改该学生的信息。当用户选择查询学生信息时,我们接收要查询的学生的 ID,并在结构体数组中查找该学生的位置并输出其信息。当用户选择退出时,我们直接退出程序。
需要注意的是,在这个示例程序中,我们使用了一个宏定义 `MAX_STUDENTS` 来限制最大学生数量,这样可以避免数组越界错误。同时,我们使用了一个变量 `num_students` 来记录当前学生的总数,这个变量初始化为零,每次添加学生时会自增一,每次删除学生时会自减一。这样可以避免由于删除学生导致数组中出现空洞而造成的问题。
阅读全文