本题要求用结构体来存储三个学生的成绩,每个学生有3门课的成绩(成绩为小数),从键盘输入以上数据(包括姓名以及各课程成绩),计算出平均成绩,然后按照平均分的降序排列输出。
时间: 2023-04-28 10:00:15 浏览: 163
可以定义一个结构体,包含学生姓名和三门课程成绩,然后定义一个数组,存储三个学生的信息。从键盘输入数据后,可以计算每个学生的平均成绩,并将平均成绩作为一个新的属性存储在结构体中。最后,可以使用冒泡排序或快速排序等算法,按照平均分的降序排列输出学生信息。
相关问题
用结构体存储3个学生成绩降序排序 c语言
好的,以下是实现方式:
```c
#include <stdio.h>
struct student {
char name[20];
float score1;
float score2;
float score3;
float avg_score;
};
void sort(struct student s[], int n);
int main() {
struct student s[3];
int i;
// 输入学生信息
for (i = 0; i < 3; i++) {
printf("请输入第%d个学生的姓名:", i + 1);
scanf("%s", s[i].name);
printf("请输入第%d个学生的三门课成绩:", i + 1);
scanf("%f%f%f", &s[i].score1, &s[i].score2, &s[i].score3);
s[i].avg_score = (s[i].score1 + s[i].score2 + s[i].score3) / 3.0; // 计算平均分
}
// 按平均分降序排序
sort(s, 3);
// 输出排序结果
printf("\n按平均分降序排序结果如下:\n");
for (i = 0; i < 3; i++) {
printf("%s的平均分为:%.2f\n", s[i].name, s[i].avg_score);
}
return 0;
}
void sort(struct student s[], int n) {
int i, j;
struct student temp;
for (i = 0; i < n - 1; i++) {
for (j = i + 1; j < n; j++) {
if (s[i].avg_score < s[j].avg_score) {
temp = s[i];
s[i] = s[j];
s[j] = temp;
}
}
}
}
```
以上代码中,我们首先定义了一个结构体 `student`,包含了学生的姓名和三门课成绩,以及计算得出的平均分。然后在 `main` 函数中,我们输入了三个学生的信息,并且计算出了他们的平均分。接着,我们调用 `sort` 函数对学生信息按照平均分进行降序排序,并输出排序结果。
`sort` 函数采用了简单的冒泡排序算法,对结构体数组 `s` 中的学生信息按照平均分进行降序排序。
用结构体存储3个学生成绩并算出平均值降序排序 c语言
好的,以下是示例代码:
```c
#include <stdio.h>
struct student {
char name[20];
float score1;
float score2;
float score3;
float average;
};
void sort(struct student arr[], int n);
void print(struct student arr[], int n);
int main() {
struct student s[3];
int i;
// 输入学生信息和成绩
for (i = 0; i < 3; i++) {
printf("请输入第%d个学生的姓名:", i + 1);
scanf("%s", s[i].name);
printf("请输入第%d个学生的3个成绩:", i + 1);
scanf("%f%f%f", &s[i].score1, &s[i].score2, &s[i].score3);
s[i].average = (s[i].score1 + s[i].score2 + s[i].score3) / 3; // 计算平均分
}
// 按平均分降序排序
sort(s, 3);
// 输出学生信息和成绩
printf("按平均分降序排序后的学生信息如下:\n");
print(s, 3);
return 0;
}
void sort(struct student arr[], int n) {
int i, j;
struct student temp;
for (i = 0; i < n - 1; i++) {
for (j = i + 1; j < n; j++) {
if (arr[i].average < arr[j].average) {
temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
}
}
}
void print(struct student arr[], int n) {
int i;
for (i = 0; i < n; i++) {
printf("姓名:%s,平均分:%.2f\n", arr[i].name, arr[i].average);
}
}
```
在这个示例中,我们定义了一个名为 `student` 的结构体,其中包含了学生姓名和3个成绩,还有一个平均分成员变量。我们首先在 `main` 函数中输入学生信息和成绩,并计算出平均分。然后调用 `sort` 函数对学生按平均分降序排序。最后调用 `print` 函数输出排序结果。`sort` 函数使用了简单的冒泡排序算法,而 `print` 函数只是简单地输出每个学生的姓名和平均分。