发布时间:2025-12-10 23:57:07 浏览次数:12
下面是一个使用C语言实现学生成绩管理系统的简单示例:
#include <stdio.h>#include <stdlib.h>#define MAX_STUDENTS 100typedef 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结构体来存储学生的姓名、学号和分数。通过使用数组来存储多个学生的信息,可以实现学生成绩的管理功能。用户可以选择添加学生、显示学生列表和搜索学生这三个操作。学生的信息会在程序运行期间保存在内存中,退出程序后将会丢失。如果需要长期保存学生的信息,可以考虑使用文件或数据库进行存储。