//利用顺序表完成一个班级学生课程成绩的简单管理#include<stdio.h>#include<stdlib.h>#include<conio.h>#define MAXSIZE 100 //
时间: 2024-10-12 15:01:04 浏览: 41
用顺序表实现学生成绩管理系统
4星 · 用户满意度95%
这是一个简单的 C 语言程序片段,用于管理一个班级学生的课程成绩。它使用顺序表(如数组)作为数据结构,`MAXSIZE` 定义了列表的最大容量为 100 个元素。
```c
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#define MAXSIZE 100
// 定义顺序表结构体
typedef struct {
char name[20]; // 学生姓名
int scores[MAXSIZE]; // 课程分数数组
int count; // 当前记录数
} StudentList;
// 函数声明
void inputStudent(StudentList *list); // 输入学生信息
void displayStudent(StudentList *list); // 显示学生信息
void averageScore(StudentList *list); // 计算平均分
int main() {
StudentList studentList;
inputStudent(&studentList);
displayStudent(&studentList);
averageScore(&studentList);
return 0;
}
// 输入学生信息函数
void inputStudent(StudentList *list) {
list->count = 0;
while (list->count < MAXSIZE) {
printf("请输入学生 %d 的姓名:", list->count + 1);
fgets(list->name, sizeof(list- 1] = '\0'; // 去除换行符
printf("请输入 %d 门课程的成绩: ", MAXSIZE);
for (int i = 0; i < MAXSIZE; ++i) {
scanf("%d", &list->scores[i]);
}
++list->count;
}
}
// 显示学生信息函数
void displayStudent(StudentList *list) {
printf("\n学生信息:\n");
for (int i = 0; i < list->count; ++i) {
printf("姓名: %s\n", list->name);
printf("成绩: ");
for (int j = 0; j < MAXSIZE; ++j) {
if (list->scores[j] != 0) {
printf("%d ", list->scores[j]);
}
}
printf("\n");
}
}
// 计算平均分函数
void averageScore(StudentList *list) {
float sum = 0;
for (int i = 0; i < list->count && i < MAXSIZE; ++i) {
if (list->scores[i] != 0) {
sum += list->scores[i];
}
}
if (list->count > 0) {
printf("平均分: %.2f\n", sum / list->count);
} else {
printf("没有输入成绩。\n");
}
}
```
在这个程序中,我们创建了一个名为 `StudentList` 的结构体,其中包含了学生姓名、分数数组以及记录计数。然后定义了一些辅助函数,分别用于输入学生信息、显示学生信息以及计算平均分。主函数中先初始化学生列表,接着调用这些函数来管理学生的课程成绩。
阅读全文