using namespace std;const int MAX_STUDENTS = 100; // 最大学生数const int NUM_SUBJECTS = 3; // 科目数struct Student { string id; // 学号 string name; // 姓名 int scores[NUM_SUBJECTS]; // 成绩 double averageScore; // 平均成绩};Student students[MAX_STUDENTS]; // 学生数组int numStudents = 0; // 学生数// 显示菜单void showMenu() { cout << "===================\n"; cout << "1. 插入学生记录\n"; cout << "2. 删除学生记录\n"; cout << "3. 修改学生记录\n"; cout << "4. 按任一单科成绩排序\n"; cout << "5. 计算每名学生的平均成绩\n"; cout << "6. 统计任一单科成绩不及格的学生人数\n"; cout << "7. 根据平均成绩将成绩表按由高到低的次序排列\n"; cout << "8. 输出成绩表\n"; cout << "9. 保存成绩表到文件\n"; cout << "10. 从文件读取成绩表\n"; cout << "0. 退出程序\n"; cout << "===================\n";}解释这段代码
时间: 2024-02-26 18:52:23 浏览: 29
这段代码定义了一些常量和一个结构体类型Student,以及一个存储Student类型的数组students和一个整型变量numStudents。同时,它还定义了一个函数showMenu,用于显示程序的菜单。菜单包括了十个选项,分别是插入学生记录、删除学生记录、修改学生记录、按任一单科成绩排序、计算每名学生的平均成绩、统计任一单科成绩不及格的学生人数、根据平均成绩将成绩表按由高到低的次序排列、输出成绩表、保存成绩表到文件和从文件读取成绩表。
相关问题
运用C语言实现学生成绩管理系统的基本功能,要求: (1) 成绩录入功能:能够录入科目名称和科目数量,然后录入学生成绩。 (2) 成绩浏览功能:可以显示所有录入的成绩。 (3) 成绩排序功能:能够按指定字段排序。例如学号、姓名、总成绩等。 (4) 成绩查找功能:按照指定字段查找成绩。
好的,下面是一个简单的实现示例,包含了成绩录入、浏览、排序和查找四个功能。该程序使用结构体存储学生信息和成绩,使用动态数组存储每个学生的成绩。
```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;
}
```
这个程序还有很多功能没有实现,例如修改、删除、统计和保存等,你可以根据自己的需求进行扩展。
输入一组学生信息并保存到文件中。学生信息包括学号,姓名,5门课的分数。 要求使用结构体数组做函数参数编程。
好的,可以使用以下代码实现:
```c++
#include <iostream>
#include <fstream>
using namespace std;
const int MAX_STUDENTS = 100; // 最大学生数
const int NUM_SUBJECTS = 5; // 科目数
// 学生结构体
struct Student {
int id; // 学号
string name; // 姓名
double scores[NUM_SUBJECTS]; // 分数
};
// 输入学生信息
void inputStudents(Student students[], int& numStudents) {
cout << "请输入学生数:";
cin >> numStudents;
for (int i = 0; i < numStudents; i++) {
cout << "请输入第 " << i+1 << " 个学生的信息:" << endl;
cout << "学号:";
cin >> students[i].id;
cout << "姓名:";
cin >> students[i].name;
cout << "五门课的分数:";
for (int j = 0; j < NUM_SUBJECTS; j++) {
cin >> students[i].scores[j];
}
}
}
// 保存学生信息到文件
void saveStudents(Student students[], int numStudents) {
ofstream fout("students.txt");
fout << numStudents << endl; // 先写入学生数
for (int i = 0; i < numStudents; i++) {
fout << students[i].id << " " << students[i].name << " ";
for (int j = 0; j < NUM_SUBJECTS; j++) {
fout << students[i].scores[j] << " ";
}
fout << endl;
}
fout.close();
}
int main() {
Student students[MAX_STUDENTS];
int numStudents;
inputStudents(students, numStudents);
saveStudents(students, numStudents);
return 0;
}
```
在此程序中,我们定义了一个 `Student` 结构体,包含了学生的学号、姓名和五门课的分数。我们使用 `inputStudents` 函数输入学生信息,并使用 `saveStudents` 函数将学生信息保存到文件中。在 `saveStudents` 函数中,我们使用了 `ofstream` 类型的对象 `fout` 来打开文件,并将学生信息写入到文件中。
注意,我们在保存学生信息时,先写入了学生数,这是为了在后面读取学生信息时方便知道需要读取多少个学生的信息。当然,读取学生信息时也需要先读取学生数。
如果想要读取保存的学生信息,可以使用以下代码:
```c++
// 从文件中读取学生信息
void loadStudents(Student students[], int& numStudents) {
ifstream fin("students.txt");
fin >> numStudents;
for (int i = 0; i < numStudents; i++) {
fin >> students[i].id >> students[i].name;
for (int j = 0; j < NUM_SUBJECTS; j++) {
fin >> students[i].scores[j];
}
}
fin.close();
}
```
这里我们使用了 `ifstream` 类型的对象 `fin` 来打开文件,并将学生信息从文件中读取到 `students` 数组中。
相关推荐
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)