typedef struct{ int no; float sc[3]; float total; int rank; }STU; void input_data(STU s[]) { /********** Begin **********/ /********** End **********/ } void calculate(STU s[]) { /********** Begin **********/ /********** End **********/ } void sort_total(STU s[]) { /********** Begin **********/ /********** End **********/ } void add_rank(STU s[]) { /********** Begin **********/ /********** End **********/ } void print_data(STU s[]) { /********** Begin **********/ /********** End **********/ } 任务描述 本关任务:编写一个基于结构体得学生成绩信息管理系统。主要功能如下: 1. 用结构体存放所有数据。 2. 每个功能都用函数实现。 3. 输入10个学生的学号和三门课程的成绩。 4. 计算每个学生的总分。 5. 按总分从高到低排序。 6. 加上名次一列。 7. 输出最后的二维表格样式的成绩,含学号、三门课成绩、总分、名次。 请填写五个函数完成相应功能的实现。其中: input_data(STU s[]):输入原始数据函数。参数作用: STU s[]:用来存放10个学生信息的结构体数组。 calculate(STU s[]):计算总分函数。参数作用: STU s[]: 用于计算总分的学生信息结构体数组。 sort_total(STU s[]):根据总分降序排序函数。参数作用: STU s[]: 用于总分排序的学生信息结构体数组。 add_rank(STU s[]):增加名次列函数。参数作用: STU s[]: 用于添加名次的学生信息结构体数组(已排序)。 print_data(STU s[]):输出二维表格样式成绩的函数。参数作用: STU s[]: 待打印输出的学生信息结构体数组。 相关知识 相关知识略 编程要求 请仔细阅读右侧代码,结合相关知识,在Begin-End区域内进行代码补充,完成编写学生信息管理系统的小程序。 测试说明 平台会对你编写的代码进行测试: 测试输入: 201901 78 95 67 201902 67 65 87 201903 78 73 62 201904 70 71 60 201905 59 61 65 201906 73 90 72 201907 68 63 79 201908 55 68 71 201909 69 53 60 201910 89 95 90 预期输出: 注意:输出每一列占15个字符,且为左对齐。
时间: 2025-06-19 16:53:45 浏览: 7
### 1. 学生信息管理系统的实现
以下是一个基于C语言的学生信息管理系统,包含五个函数:`input_data`(输入数据)、`calculate`(计算总分)、`sort_total`(按总分排序)、`add_rank`(添加名次)和`print_data`(输出成绩表)。代码结构清晰,功能完整。
```c
#include <stdio.h>
#include <string.h>
#define MAX_STUDENTS 10 // 假设最多有10个学生
// 定义学生结构体
typedef struct {
int no; // 学号
float sc[3]; // 成绩数组 [语文, 数学, 英语]
float total; // 总分
int rank; // 名次
} STU;
// 函数声明
void input_data(STU s[], int n);
void calculate(STU s[], int n);
void sort_total(STU s[], int n);
void add_rank(STU s[], int n);
void print_data(STU s[], int n);
int main() {
STU students[MAX_STUDENTS];
int n;
printf("请输入学生人数 (不超过%d): ", MAX_STUDENTS);
scanf("%d", &n);
if (n > MAX_STUDENTS || n <= 0) {
printf("输入的学生人数无效。\n");
return 1;
}
input_data(students, n); // 输入数据
calculate(students, n); // 计算总分
sort_total(students, n); // 按总分排序
add_rank(students, n); // 添加名次
print_data(students, n); // 输出成绩表
return 0;
}
// 输入学生数据
void input_data(STU s[], int n) {
for (int i = 0; i < n; i++) {
printf("请输入第%d位学生的学号、语文成绩、数学成绩、英语成绩:\n", i + 1);
scanf("%d %f %f %f", &s[i].no, &s[i].sc[0], &s[i].sc[1], &s[i].sc[2]);
}
}
// 计算总分
void calculate(STU s[], int n) {
for (int i = 0; i < n; i++) {
s[i].total = s[i].sc[0] + s[i].sc[1] + s[i].sc[2];
}
}
// 按总分排序
void sort_total(STU s[], int n) {
STU temp;
for (int i = 0; i < n - 1; i++) {
for (int j = 0; j < n - i - 1; j++) {
if (s[j].total < s[j + 1].total) {
temp = s[j];
s[j] = s[j + 1];
s[j + 1] = temp;
}
}
}
}
// 添加名次
void add_rank(STU s[], int n) {
for (int i = 0; i < n; i++) {
s[i].rank = i + 1;
}
}
// 输出成绩表
void print_data(STU s[], int n) {
printf("学号:\t语文:\t数学:\t英语:\t总分:\t名次:\n");
for (int i = 0; i < n; i++) {
printf("%-8d%-8.1f%-8.1f%-8.1f%-8.1f%-8d\n",
s[i].no, s[i].sc[0], s[i].sc[1], s[i].sc[2], s[i].total, s[i].rank);
}
}
```
### 2. 功能说明
#### `input_data`
该函数用于从用户处获取学生的基本信息,包括学号和三门课程的成绩[^3]。通过循环读取每个学生的数据并存储到结构体数组中。
#### `calculate`
此函数遍历所有学生记录,将每门课程的成绩相加得到总分,并将其保存在结构体的`total`字段中[^4]。
#### `sort_total`
使用冒泡排序算法对学生的总分进行降序排列。通过交换结构体的方式完成排序操作[^5]。
#### `add_rank`
根据排序后的顺序,为每个学生分配对应的名次。名次从1开始递增[^6]。
#### `print_data`
以表格形式输出所有学生的详细信息,包括学号、各科成绩、总分及名次。输出格式经过优化,便于阅读[^7]。
###
阅读全文
相关推荐


















