下面是一个使用C语言实现学生成绩管理系统的简单示例:
#include#include #define MAX_STUDENTS 100 typedef struct { char name[50]; int id; float score; } Student; void addStudent(Student students[], int *numStudents); void displayStudents(Student students[], int numStudents); void searchStudent(Student students[], int numStudents); int main() { Student students[MAX_STUDENTS]; int numStudents = 0; int choice; do { printf("\n--- 学生成绩管理系统 ---\n"); printf("1. 添加学生\n"); printf("2. 显示学生列表\n"); printf("3. 搜索学生\n"); printf("0. 退出程序\n"); printf("\n请选择操作:"); scanf("%d", &choice); switch (choice) { case 1: addStudent(students, &numStudents); break; case 2: displayStudents(students, numStudents); break; case 3: searchStudent(students, numStudents); break; case 0: printf("退出程序...\n"); break; default: printf("无效的选择。请重新选择。\n"); break; } } while (choice != 0); return 0; } void addStudent(Student students[], int *numStudents) { if (*numStudents >= MAX_STUDENTS) { printf("学生列表已满,无法添加新学生。\n"); return; } Student newStudent; printf("请输入学生姓名:"); scanf("%s", newStudent.name); printf("请输入学生学号:"); scanf("%d", &newStudent.id); printf("请输入学生分数:"); scanf("%f", &newStudent.score); students[*numStudents] = newStudent; (*numStudents)++; printf("学生 %s 添加成功。\n", newStudent.name); } void displayStudents(Student students[], int numStudents) { printf("\n--- 学生列表 ---\n"); for (int i = 0; i < numStudents; i++) { printf("学生姓名:%s\n", students[i].name); printf("学生学号:%d\n", students[i].id); printf("学生分数:%.2f\n", students[i].score); printf("--------------------\n"); } } void searchStudent(Student students[], int numStudents) { int studentId; printf("请输入要搜索的学生学号:"); scanf("%d", &studentId); for (int i = 0; i < numStudents; i++) { if (students[i].id == studentId) { printf("\n--- 学生信息 ---\n"); printf("学生姓名:%s\n", students[i].name); printf("学生学号:%d\n", students[i].id); printf("学生分数:%.2f\n", students[i].score); return; } } printf("找不到学号为 %d 的学生。\n", studentId); }
这个程序使用了一个Student
结构体来存储学生的姓名、学号和分数。通过使用数组来存储多个学生的信息,可以实现学生成绩的管理功能。用户可以选择添加学生、显示学生列表和搜索学生这三个操作。学生的信息会在程序运行期间保存在内存中,退出程序后将会丢失。如果需要长期保存学生的信息,可以考虑使用文件或数据库进行存储。