c语言学生籍贯管理系统
时间: 2023-09-25 15:16:07 浏览: 84
这是一个简单的C语言学生籍贯管理系统的代码示例,包括添加、删除、查询和显示功能。
```
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX_STUDENT_NUM 100 // 最大学生数量
#define MAX_NAME_LENGTH 20 // 最长姓名长度
#define MAX_PROVINCE_LENGTH 20 // 最长省份名称长度
// 学生结构体
typedef struct {
int id; // 学号
char name[MAX_NAME_LENGTH]; // 姓名
char province[MAX_PROVINCE_LENGTH]; // 籍贯
} Student;
// 全局变量,存储所有学生信息
Student students[MAX_STUDENT_NUM];
int student_num = 0; // 当前学生数量
// 添加学生
void add_student() {
if (student_num == MAX_STUDENT_NUM) {
printf("Error: 学生数量已达到最大值,无法添加新学生。\n");
return;
}
printf("请输入学生信息:\n");
Student student;
printf("学号:");
scanf("%d", &(student.id));
printf("姓名:");
scanf("%s", student.name);
printf("籍贯:");
scanf("%s", student.province);
students[student_num++] = student; // 将新学生加入学生列表
printf("已添加学生:%s(学号:%d,籍贯:%s)\n", student.name, student.id, student.province);
}
// 删除学生
void delete_student() {
int id;
printf("请输入要删除的学生学号:");
scanf("%d", &id);
int i;
for (i = 0; i < student_num; i++) {
if (students[i].id == id) {
printf("已删除学生:%s(学号:%d,籍贯:%s)\n", students[i].name, students[i].id, students[i].province);
// 将后面的学生向前移动
for (int j = i + 1; j < student_num; j++) {
students[j-1] = students[j];
}
student_num--;
return;
}
}
printf("Error: 没有找到学号为 %d 的学生。\n", id);
}
// 查询学生
void query_student() {
int id;
printf("请输入要查询的学生学号:");
scanf("%d", &id);
int i;
for (i = 0; i < student_num; i++) {
if (students[i].id == id) {
printf("学生信息:%s(学号:%d,籍贯:%s)\n", students[i].name, students[i].id, students[i].province);
return;
}
}
printf("Error: 没有找到学号为 %d 的学生。\n", id);
}
// 显示所有学生信息
void show_all_students() {
printf("所有学生信息:\n");
int i;
for (i = 0; i < student_num; i++) {
printf(" %s(学号:%d,籍贯:%s)\n", students[i].name, students[i].id, students[i].province);
}
}
int main() {
while (1) {
printf("\n请选择操作:\n");
printf("1. 添加学生\n");
printf("2. 删除学生\n");
printf("3. 查询学生\n");
printf("4. 显示所有学生信息\n");
printf("5. 退出\n\n");
int choice;
scanf("%d", &choice);
switch (choice) {
case 1:
add_student();
break;
case 2:
delete_student();
break;
case 3:
query_student();
break;
case 4:
show_all_students();
break;
case 5:
exit(0);
default:
printf("Error: 无效的选择。\n");
}
}
return 0;
}
```
阅读全文