小型学籍管理系统c语言代码实现
时间: 2023-09-21 22:13:46 浏览: 59
以下是一个简单的小型学籍管理系统的C语言代码实现:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX_STUDENTS 100 // 最大学生数量
#define MAX_NAME_LEN 20 // 姓名最大长度
// 学生结构体
typedef struct {
int id; // 学号
char name[MAX_NAME_LEN]; // 姓名
int age; // 年龄
float score; // 成绩
} Student;
int numStudents = 0; // 学生数量
Student students[MAX_STUDENTS]; // 学生数组
// 添加学生
void addStudent() {
if (numStudents >= MAX_STUDENTS) {
printf("学生数量已达上限,无法添加新学生\n");
return;
}
Student s;
printf("请输入学生信息:\n");
printf("学号:");
scanf("%d", &s.id);
printf("姓名:");
scanf("%s", s.name);
printf("年龄:");
scanf("%d", &s.age);
printf("成绩:");
scanf("%f", &s.score);
students[numStudents] = s;
numStudents++;
printf("添加成功!\n");
}
// 删除学生
void deleteStudent() {
int id;
printf("请输入要删除的学生学号:");
scanf("%d", &id);
int index = -1;
for (int i = 0; i < numStudents; i++) {
if (students[i].id == id) {
index = i;
break;
}
}
if (index == -1) {
printf("找不到该学生\n");
return;
}
for (int i = index; i < numStudents - 1; i++) {
students[i] = students[i + 1];
}
numStudents--;
printf("删除成功!\n");
}
// 显示学生
void showStudent() {
int id;
printf("请输入要查找的学生学号:");
scanf("%d", &id);
int index = -1;
for (int i = 0; i < numStudents; i++) {
if (students[i].id == id) {
index = i;
break;
}
}
if (index == -1) {
printf("找不到该学生\n");
return;
}
Student s = students[index];
printf("学号:%d,姓名:%s,年龄:%d,成绩:%.2f\n", s.id, s.name, s.age, s.score);
}
// 显示所有学生
void showAllStudents() {
if (numStudents == 0) {
printf("暂无学生信息\n");
return;
}
printf("学号\t姓名\t年龄\t成绩\n");
for (int i = 0; i < numStudents; i++) {
Student s = students[i];
printf("%d\t%s\t%d\t%.2f\n", s.id, s.name, s.age, s.score);
}
}
// 主函数
int main() {
while (1) {
printf("\n请选择操作:\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:
addStudent();
break;
case 2:
deleteStudent();
break;
case 3:
showStudent();
break;
case 4:
showAllStudents();
break;
case 5:
return 0;
default:
printf("无效的选项\n");
}
}
}
```
该程序实现了四个基本功能:添加学生、删除学生、查找学生和显示所有学生。通过一个无限循环的菜单,用户可以选择要执行的操作。在添加、删除和查找学生时,用户需要输入学生的学号,程序会根据学号在学生数组中查找对应的学生。如果找不到该学生,程序会提示用户。在显示所有学生时,程序会遍历学生数组并输出所有学生的信息。