用C语言写程序设计校选课期末计划安排在第十五周周五下午,有学生反映第十五周周末恰逢端午节假期,已请假提前回家。 经过协商,该课程期末考试共进行两次,分别在第十五周周五下午和第十六周周五下午。 如果学生两次考试都参加,则该课程期末成绩取两次成绩最高分。如果只参加了一次,则该次成绩即为期末考试成绩。 请你帮老师统计下每个学生该门课程的期末成绩。 输入格式: 输入在一行中给出正整数N(≤10)。 随后N行,每行给出一位学生的信息,格式为“学号 姓名 第一次成绩 第二次成绩”,中间以空格分隔。 其中学号为由15个数字组成的字符串,姓名为长度不超过20的不包含空白字符的非空字符串, 成绩为[0,100]区间内的整数,如果该次考试没参加,成绩为0。 输出格式: 按照学号递增次序,每行输出一个学生的学号、姓名和期末成绩,间隔一个空格。
时间: 2023-12-27 10:05:34 浏览: 136
c语言程序设计学生成绩设计
这道题目需要先读入每个学生的信息,然后进行处理计算期末成绩,最后按照学号递增的顺序输出每个学生的信息和期末成绩。可以使用结构体来存储每个学生的信息和期末成绩,再使用快速排序将学生信息按照学号递增排序输出。
以下是一份C语言的代码示例:
```c
#include <stdio.h>
#include <string.h>
#define MAX_N 10 // 最大学生数
#define MAX_NAME_LEN 21 // 姓名最大长度
#define MAX_ID_LEN 16 // 学号最大长度
// 学生信息结构体
typedef struct {
char id[MAX_ID_LEN]; // 学号
char name[MAX_NAME_LEN]; // 姓名
int score1; // 第一次成绩
int score2; // 第二次成绩
int final_score; // 期末成绩
} Student;
// 快速排序
void quick_sort(Student stu[], int left, int right) {
if (left >= right) return;
int i = left, j = right;
Student pivot = stu[left];
while (i < j) {
while (i < j && strcmp(stu[j].id, pivot.id) >= 0) j--;
stu[i] = stu[j];
while (i < j && strcmp(stu[i].id, pivot.id) <= 0) i++;
stu[j] = stu[i];
}
stu[i] = pivot;
quick_sort(stu, left, i - 1);
quick_sort(stu, i + 1, right);
}
int main() {
int n;
scanf("%d", &n);
Student stu[MAX_N];
for (int i = 0; i < n; i++) {
scanf("%s %s %d %d", stu[i].id, stu[i].name, &stu[i].score1, &stu[i].score2);
// 计算期末成绩
if (stu[i].score1 > stu[i].score2) {
stu[i].final_score = stu[i].score1;
} else {
stu[i].final_score = stu[i].score2;
}
}
quick_sort(stu, 0, n - 1);
for (int i = 0; i < n; i++) {
printf("%s %s %d\n", stu[i].id, stu[i].name, stu[i].final_score);
}
return 0;
}
```
这份代码中,我们先读入学生数量n,然后用一个结构体数组stu来存储每个学生的信息和期末成绩。在读入每个学生的信息时,我们根据第一次成绩和第二次成绩计算出期末成绩并存储到结构体中。最后使用快速排序将学生信息按照学号递增排序,并输出每个学生的学号、姓名和期末成绩。
阅读全文