运用C语言实现学生成绩管理系统的基本功能,要求: (1) 成绩录入功能:能够录入科目名称和科目数量,然后录入学生成绩。 (2) 成绩浏览功能:可以显示所有录入的成绩。 (3) 成绩排序功能:能够按指定字段排序。例如学号、姓名、总成绩等。 (4) 成绩查找功能:按照指定字段查找成绩。
时间: 2024-03-27 13:35:10 浏览: 57
好的,下面是一个简单的实现示例,包含了成绩录入、浏览、排序和查找四个功能。该程序使用结构体存储学生信息和成绩,使用动态数组存储每个学生的成绩。
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX_SUBJECTS 10 // 最大科目数量
#define MAX_NAME_LEN 20 // 姓名最大长度
#define MAX_STUDENTS 100 // 最大学生数量
// 学生信息结构体
typedef struct {
int id; // 学号
char name[MAX_NAME_LEN]; // 姓名
int scores[MAX_SUBJECTS]; // 成绩数组
int num_subjects; // 科目数量
} Student;
// 学生数组
Student students[MAX_STUDENTS];
int num_students = 0; // 学生数量
// 添加一个学生
void add_student() {
if (num_students >= MAX_STUDENTS) {
printf("已达到最大学生数量,无法添加!\n");
return;
}
printf("请输入学号:");
scanf("%d", &students[num_students].id);
printf("请输入姓名:");
scanf("%s", students[num_students].name);
printf("请输入科目数量:");
scanf("%d", &students[num_students].num_subjects);
printf("请输入每个科目的名称和分数:\n");
for (int i = 0; i < students[num_students].num_subjects; i++) {
scanf("%s %d", subjects[i], &students[num_students].scores[i]);
}
num_students++;
printf("添加成功!\n");
}
// 显示所有学生信息
void show_students() {
if (num_students == 0) {
printf("没有学生信息!\n");
return;
}
printf("学号\t姓名\t");
for (int i = 0; i < students[0].num_subjects; i++) {
printf("%s\t", subjects[i]);
}
printf("总分\n");
for (int i = 0; i < num_students; i++) {
int total_score = 0;
printf("%d\t%s\t", students[i].id, students[i].name);
for (int j = 0; j < students[i].num_subjects; j++) {
printf("%d\t", students[i].scores[j]);
total_score += students[i].scores[j];
}
printf("%d\n", total_score);
}
}
// 比较函数,用于排序
int compare_students(const void* a, const void* b) {
Student* s1 = (Student*)a;
Student* s2 = (Student*)b;
return s1->id - s2->id;
}
// 按学号排序
void sort_students_by_id() {
qsort(students, num_students, sizeof(Student), compare_students);
printf("排序完成!\n");
}
// 按姓名排序
void sort_students_by_name() {
// TODO: 实现按姓名排序
printf("按姓名排序功能尚未实现!\n");
}
// 按总分排序
void sort_students_by_score() {
// TODO: 实现按总分排序
printf("按总分排序功能尚未实现!\n");
}
// 查找学生
void find_student() {
int choice;
printf("请选择查找方式:\n");
printf("1. 按学号查找\n");
printf("2. 按姓名查找\n");
scanf("%d", &choice);
switch (choice) {
case 1:
// 按学号查找
int id;
printf("请输入学号:");
scanf("%d", &id);
for (int i = 0; i < num_students; i++) {
if (students[i].id == id) {
// 找到了
printf("学号\t姓名\t");
for (int j = 0; j < students[0].num_subjects; j++) {
printf("%s\t", subjects[j]);
}
printf("总分\n");
int total_score = 0;
printf("%d\t%s\t", students[i].id, students[i].name);
for (int j = 0; j < students[i].num_subjects; j++) {
printf("%d\t", students[i].scores[j]);
total_score += students[i].scores[j];
}
printf("%d\n", total_score);
return;
}
}
printf("没有找到该学生!\n");
break;
case 2:
// 按姓名查找
// TODO: 实现按姓名查找
printf("按姓名查找功能尚未实现!\n");
break;
default:
printf("无效的选项!\n");
break;
}
}
int main() {
int choice;
while (1) {
printf("请选择操作:\n");
printf("1. 添加学生\n");
printf("2. 查看学生信息\n");
printf("3. 按学号排序\n");
printf("4. 按姓名排序\n");
printf("5. 按总分排序\n");
printf("6. 查找学生\n");
printf("7. 退出\n");
scanf("%d", &choice);
switch (choice) {
case 1:
add_student();
break;
case 2:
show_students();
break;
case 3:
sort_students_by_id();
break;
case 4:
sort_students_by_name();
break;
case 5:
sort_students_by_score();
break;
case 6:
find_student();
break;
case 7:
return 0;
default:
printf("无效的选项!\n");
break;
}
}
return 0;
}
```
这个程序还有很多功能没有实现,例如修改、删除、统计和保存等,你可以根据自己的需求进行扩展。
阅读全文