输入n名同学的成绩和学号, 1.将小于60分的同学归零,大于60分的同学,统计每个等级的人数 2.计算n名同学的平均值、以及最大值、最小值的学号 3.创建一个4*5的矩阵,将每行的最大值搜集出来并输出,再对矩阵按列排序c语言编写
时间: 2024-12-13 12:23:56 浏览: 7
为了完成这个任务,我们可以使用C语言编写一个结构体来存储学生的成绩和学号,然后创建一个数组或动态分配内存来存放所有学生的信息。以下是步骤和代码示例:
```c
#include <stdio.h>
#include <stdlib.h>
// 定义学生结构体
typedef struct {
int score;
int id;
} Student;
void zero_scores(Student students[], int n) {
for (int i = 0; i < n; i++) {
if (students[i].score < 60) {
students[i].score = 0;
}
}
}
void count_grades(Student *students, int n) {
int grades[4] = {0};
for (int i = 0; i < n; i++) {
grades[students[i].score / 10]++;
}
printf("各等级人数:");
for (int i = 0; i < 4; i++) {
printf("%d-%d分:%d人\n", i * 10, (i + 1) * 10 - 1, grades[i]);
}
}
double calculate_stats(Student students[], int n) {
double sum = 0;
int max_id = 0, min_id = 0;
for (int i = 0; i < n; i++) {
sum += students[i].score;
if (students[i].score > students[max_id].score) {
max_id = i;
} else if (students[i].score < students[min_id].score) {
min_id = i;
}
}
double avg = sum / n;
printf("平均值:%.2f, 最大值:第%d号(%d分), 最小值:第%d号(%d分)\n", avg, max_id + 1, students[max_id].score, min_id + 1, students[min_id].score);
}
void print_matrix(int matrix[4][5]) {
for (int i = 0; i < 4; i++) {
for (int j = 0; j < 5; j++) {
printf("%d ", matrix[i][j]);
}
printf("\n");
}
// 对矩阵按列排序,这里简化处理,实际应用需要自定义函数
for (int i = 0; i < 4; i++) {
for (int j = 0; j < 4; j++) {
for (int k = j + 1; k < 4; k++) {
if (matrix[j][i] > matrix[k][i]) {
int temp = matrix[j][i];
matrix[j][i] = matrix[k][i];
matrix[k][i] = temp;
}
}
}
}
printf("按列排序后的矩阵:\n");
print_matrix(matrix);
}
int main() {
int num_students;
printf("请输入学生数量: ");
scanf("%d", &num_students);
// 分配内存
Student *students = malloc(num_students * sizeof(Student));
if (!students) {
printf("内存分配失败\n");
return 1;
}
// 输入学生信息
for (int i = 0; i < num_students; i++) {
scanf("Score:%d ID:%d", &students[i].score, &students[i].id);
}
// 操作数据
zero_scores(students, num_students);
count_grades(students, num_students);
calculate_stats(students, num_students);
// 创建矩阵并填充
int matrix[4][5] = {{0}};
for (int i = 0; i < num_students && i < 20; i++) {
matrix[i / 5][i % 5] = students[i].score;
}
// 输出矩阵
print_matrix(matrix);
free(students); // 释放内存
return 0;
}
```
阅读全文