此题是要求实现一个学生成绩管理系统v5.0,某班有最多不超过30人(具体人数由键盘输入),参加期末考试,最多不超过6门(具体门数由键盘输入)。参考学生成绩管理系统v4.0,定义结构体类型,用结构体数组作参数,编程实现如下菜单驱动的学生成绩管理系统: (1)录入每个学生的学号、姓名和各科考试成绩; (2)计算每门课的总分和平均分; (3)计算每个学生的总分和平均分; (4)按每个学生的总分由高到低排出名次表; (5)按每个学生的总分由低到高排出名次表;

时间: 2024-01-14 18:03:01 浏览: 22
好的,我了解这个题目。针对你的问题,我可以给出以下代码实现,帮助你更好地理解: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX_NUM 30 // 最大学生数 #define MAX_COURSE 6 // 最大科目数 // 学生结构体 typedef struct student { char id[10]; // 学号 char name[20]; // 姓名 int score[MAX_COURSE]; // 各科成绩 int total_score; // 总分 float avg_score; // 平均分 } Student; // 录入学生信息 void input(Student *stu, int num, int course_num) { int i, j; for (i = 0; i < num; i++) { printf("请输入第%d个学生的学号、姓名和各科成绩(用空格分隔):\n", i + 1); scanf("%s%s", stu[i].id, stu[i].name); for (j = 0; j < course_num; j++) { scanf("%d", &stu[i].score[j]); stu[i].total_score += stu[i].score[j]; } stu[i].avg_score = (float)stu[i].total_score / course_num; } } // 计算每门课的总分和平均分 void calc_course_score(Student *stu, int num, int course_num, int *course_total_score, float *course_avg_score) { int i, j; for (j = 0; j < course_num; j++) { course_total_score[j] = 0; for (i = 0; i < num; i++) { course_total_score[j] += stu[i].score[j]; } course_avg_score[j] = (float)course_total_score[j] / num; } } // 计算每个学生的总分和平均分 void calc_student_score(Student *stu, int num) { int i; for (i = 0; i < num; i++) { stu[i].total_score = 0; int j; for (j = 0; j < MAX_COURSE; j++) { stu[i].total_score += stu[i].score[j]; } stu[i].avg_score = (float)stu[i].total_score / MAX_COURSE; } } // 按每个学生的总分由高到低排出名次表 void sort_by_total_score_desc(Student *stu, int num) { int i, j; for (i = 0; i < num - 1; i++) { for (j = 0; j < num - i - 1; j++) { if (stu[j].total_score < stu[j + 1].total_score) { Student tmp = stu[j]; stu[j] = stu[j + 1]; stu[j + 1] = tmp; } } } } // 按每个学生的总分由低到高排出名次表 void sort_by_total_score_asc(Student *stu, int num) { int i, j; for (i = 0; i < num - 1; i++) { for (j = 0; j < num - i - 1; j++) { if (stu[j].total_score > stu[j + 1].total_score) { Student tmp = stu[j]; stu[j] = stu[j + 1]; stu[j + 1] = tmp; } } } } // 按学号从小到大排出成绩表 void sort_by_id(Student *stu, int num) { int i, j; for (i = 0; i < num - 1; i++) { for (j = 0; j < num - i - 1; j++) { if (strcmp(stu[j].id, stu[j + 1].id) > 0) { Student tmp = stu[j]; stu[j] = stu[j + 1]; stu[j + 1] = tmp; } } } } // 按姓名的字母顺序排出成绩表 void sort_by_name(Student *stu, int num) { int i, j; for (i = 0; i < num - 1; i++) { for (j = 0; j < num - i - 1; j++) { if (strcmp(stu[j].name, stu[j + 1].name) > 0) { Student tmp = stu[j]; stu[j] = stu[j + 1]; stu[j + 1] = tmp; } } } } // 输出成绩单 void print_score(Student *stu, int num, int course_num) { printf("学号\t姓名"); int i, j; for (i = 0; i < course_num; i++) { printf("\t科目%d", i + 1); } printf("\t总分\t平均分\n"); for (i = 0; i < num; i++) { printf("%s\t%s", stu[i].id, stu[i].name); for (j = 0; j < course_num; j++) { printf("\t%d", stu[i].score[j]); } printf("\t%d\t%.2f\n", stu[i].total_score, stu[i].avg_score); } } // 输出每门课的总分和平均分 void print_course_score(int *course_total_score, float *course_avg_score, int course_num) { printf("科目\t总分\t平均分\n"); int i; for (i = 0; i < course_num; i++) { printf("科目%d\t%d\t%.2f\n", i + 1, course_total_score[i], course_avg_score[i]); } } int main() { int num, course_num; printf("请输入学生人数和科目数:\n"); scanf("%d%d", &num, &course_num); Student *stu = (Student *)malloc(num * sizeof(Student)); int *course_total_score = (int *)malloc(course_num * sizeof(int)); float *course_avg_score = (float *)malloc(course_num * sizeof(float)); int choice; do { printf("\n"); printf("1. 录入信息\n"); printf("2. 计算每门课的总分和平均分\n"); printf("3. 计算每个学生的总分和平均分\n"); printf("4. 按每个学生的总分由高到低排出名次表\n"); printf("5. 按每个学生的总分由低到高排出名次表\n"); printf("6. 按学号从小到大排出成绩表\n"); printf("7. 按姓名的字母顺序排出成绩表\n"); printf("0. 退出\n"); printf("请输入操作编号:\n"); scanf("%d", &choice); switch (choice) { case 1: input(stu, num, course_num); break; case 2: calc_course_score(stu, num, course_num, course_total_score, course_avg_score); print_course_score(course_total_score, course_avg_score, course_num); break; case 3: calc_student_score(stu, num); print_score(stu, num, course_num); break; case 4: calc_student_score(stu, num); sort_by_total_score_desc(stu, num); print_score(stu, num, course_num); break; case 5: calc_student_score(stu, num); sort_by_total_score_asc(stu, num); print_score(stu, num, course_num); break; case 6: sort_by_id(stu, num); print_score(stu, num, course_num); break; case 7: sort_by_name(stu, num); print_score(stu, num, course_num); break; case 0: break; default: printf("输入有误,请重新输入!\n"); break; } } while (choice != 0); free(stu); free(course_total_score); free(course_avg_score); return 0; } ``` 以上代码实现了题目所要求的功能,并且通过菜单驱动,可以方便地操作各项功能。希望能对你有所帮助。

相关推荐

最新推荐

recommend-type

中国移动省级NG2-BASS(v5.0)技术规范数据质量管理子系统分册.docx

中国移动省级NG2-BASS(v5.0)技术规范数据质量管理子系统分册.docx
recommend-type

Android 5.0以上Toast不显示的解决方法

最近在开发中我们经常会在适配5.0以后的机型遇到各种各样的问题,其中有一个不大不小的问题就是:Toast不显示问题,这篇文章就给大家总结了Android 5.0以上Toast不显示的原因与解决方法,有需要的朋友们可以参考借鉴...
recommend-type

中标麒麟高级服务器操作系统V6.5安装东方通5.0中间件操作及配置手册.docx

中标麒麟高级服务器操作系统V6.5安装东方通5.0中间件操作及配置手册.docx
recommend-type

数据资产管理实践白皮书(5.0版)-54页.pdf

《数据资产管理实践白皮书(5.0版)》结合业界数据资产管理先进理念和关注焦点,总结最新实践案例,在《数据资产管理实践白皮书(4.0版)》基础上,聚焦数据资产前沿问题、优化数据资产管理理念,进一步完善数据资产...
recommend-type

苏亚星机房管理系统V5.0常见问题与处理方法

苏亚星机房管理系统v5.0官方制作的常见问题与处理方法,针对安装使用过程中常出现的问题的解决方案。
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

spring添加xml配置文件

1. 创建一个新的Spring配置文件,例如"applicationContext.xml"。 2. 在文件头部添加XML命名空间和schema定义,如下所示: ``` <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。