某班最多不超过30人(具体人数由键盘输入)参加期末考试,最多不超过6门(具体 门数由键盘输入)。请使用模块化程序设计方法编程实现如下菜单驱动的学生成绩管理系统:(1)输入每个学生的学号、姓名和各科考试成绩; (2)计算每门课程的总分和平均分; (3)计算每个学生的总分和平均分; (4)按每个学生的总分由高到低排出名次表; (5)按每个学生的总分由低到高排出名次表; (6)按学号由小到大排出成绩表; (7)按学号查询学生排名及其考试成绩;(8)按姓名查询学生排名及其考试成绩;(9)按优秀(90~100、良好(80~89)、中等(70~79)、及格(60~69)、不及格(0~59) 5个类别,对每门课程分别统计每个类别的人数以及所占的百分比;(10)输出每个学生的学号、姓名、各科考试成绩,以及每门课程的总分和平均分。

时间: 2023-12-22 19:05:42 浏览: 82
以下是一个可能的实现,包含了菜单驱动的主程序和多个模块化的函数。代码中注释解释了每个函数的作用。请注意,此代码块仅为示例,可能需要根据具体需求进行修改和调整。 ```python # 定义全局变量,用于存储学生信息和成绩数据 students = [] num_students = 0 num_courses = 0 course_names = [] scores = [[]] def main(): global num_students, num_courses, course_names, scores # 打印菜单并等待用户输入选择 while True: print("\n学生成绩管理系统") print("1. 输入学生信息和成绩") print("2. 统计各门课程总分和平均分") print("3. 统计每个学生的总分和平均分") print("4. 按总分排名(由高到低)") print("5. 按总分排名(由低到高)") print("6. 按学号排序") print("7. 按学号或姓名查询排名和成绩") print("8. 统计优秀、良好、中等、及格、不及格人数和百分比") print("9. 输出成绩单") print("0. 退出系统") choice = input("请选择操作:") if choice == "1": num_students, num_courses, course_names, scores = input_scores() students = init_students(num_students) input_student_info(students) input_scores_info(students, num_courses, course_names, scores) elif choice == "2": course_totals, course_averages = calc_course_stats(num_students, num_courses, scores) print_course_stats(course_names, course_totals, course_averages) elif choice == "3": student_totals, student_averages = calc_student_stats(num_students, num_courses, scores) print_student_stats(students, student_totals, student_averages) elif choice == "4": sorted_students = sort_students_by_total(students, num_students, num_courses, scores, reverse=True) print_ranking(sorted_students) elif choice == "5": sorted_students = sort_students_by_total(students, num_students, num_courses, scores, reverse=False) print_ranking(sorted_students) elif choice == "6": sorted_students = sort_students_by_id(students, num_students) print_student_info(sorted_students) elif choice == "7": query_student(students, num_students) elif choice == "8": stats_by_score_range = calc_stats_by_score_range(num_students, num_courses, scores) print_score_range_stats(stats_by_score_range) elif choice == "9": print_all_scores(students, num_students, num_courses, course_names, scores) elif choice == "0": print("谢谢使用,再见!") break else: print("输入错误,请重新选择。") def input_scores(): # 输入学生数和课程数 num_students = int(input("请输入学生数:")) num_courses = int(input("请输入课程数:")) # 输入每门课程的名称 course_names = [] for i in range(num_courses): name = input("请输入第{}门课程的名称:".format(i+1)) course_names.append(name) # 初始化成绩矩阵 scores = [[0] * num_courses for i in range(num_students)] return num_students, num_courses, course_names, scores def init_students(num_students): # 初始化学生信息 students = [] for i in range(num_students): student = {"id": "", "name": ""} students.append(student) return students def input_student_info(students): # 输入每个学生的学号和姓名 for i, student in enumerate(students): student["id"] = input("请输入第{}个学生的学号:".format(i+1)) student["name"] = input("请输入第{}个学生的姓名:".format(i+1)) def input_scores_info(students, num_courses, course_names, scores): # 输入每个学生的每门成绩 for i, student in enumerate(students): print("请输入{}的成绩:".format(student["name"])) for j in range(num_courses): score = float(input("{}:".format(course_names[j]))) scores[i][j] = score def calc_course_stats(num_students, num_courses, scores): # 计算每门课程的总分和平均分 course_totals = [0] * num_courses course_averages = [0] * num_courses for i in range(num_courses): total = sum([scores[j][i] for j in range(num_students)]) average = total / num_students course_totals[i] = total course_averages[i] = average return course_totals, course_averages def print_course_stats(course_names, course_totals, course_averages): # 打印每门课程的总分和平均分 print("课程成绩统计") print("{:<10}{:<10}{:<10}".format("课程名称", "总分", "平均分")) for i in range(len(course_names)): print("{:<10}{:<10.2f}{:<10.2f}".format(course_names[i], course_totals[i], course_averages[i])) def calc_student_stats(num_students, num_courses, scores): # 计算每个学生的总分和平均分 student_totals = [0] * num_students student_averages = [0] * num_students for i in range(num_students): total = sum(scores[i]) average = total / num_courses student_totals[i] = total student_averages[i] = average return student_totals, student_averages def print_student_stats(students, student_totals, student_averages): # 打印每个学生的总分和平均分 print("学生成绩统计") print("{:<10}{:<10}{:<10}{:<10}".format("学号", "姓名", "总分", "平均分")) for i in range(len(students)): print("{:<10}{:<10}{:<10.2f}{:<10.2f}".format(students[i]["id"], students[i]["name"], student_totals[i], student_averages[i])) def sort_students_by_total(students, num_students, num_courses, scores, reverse=False): # 按总分排序 sorted_students = students.copy() sorted_students.sort(key=lambda x: sum(scores[students.index(x)]), reverse=reverse) return sorted_students def print_ranking(sorted_students): # 打印排名表 print("排名表") print("{:<10}{:<10}{:<10}{:<10}".format("排名", "学号", "姓名", "总分")) for i, student in enumerate(sorted_students): print("{:<10}{:<10}{:<10}{:<10.2f}".format(i+1, student["id"], student["name"], sum(scores[students.index(student)]))) def sort_students_by_id(students, num_students): # 按学号排序 sorted_students = students.copy() sorted_students.sort(key=lambda x: x["id"]) return sorted_students def print_student_info(sorted_students): # 打印学生信息和成绩 print("{:<10}{:<10}{:<20}".format("学号", "姓名", "成绩")) for student in sorted_students: scores_str = " ".join([str(score) for score in scores[students.index(student)]]) print("{:<10}{:<10}{:<20}".format(student["id"], student["name"], scores_str)) def query_student(students, num_students): # 按学号或姓名查询学生排名和成绩 keyword = input("请输入学号或姓名:") found_students = [] for student in students: if keyword in student["id"] or keyword in student["name"]: found_students.append(student) if len(found_students) == 0: print("未找到匹配的学生。") elif len(found_students) == 1: ranking = students.index(found_students[0]) + 1 scores_str = " ".join([str(score) for score in scores[students.index(found_students[0])]]) print("{:<10}{:<10}{:<20}".format("学号", "姓名", "成绩")) print("{:<10}{:<10}{:<20}".format(found_students[0]["id"], found_students[0]["name"], scores_str)) print("排名:{}".format(ranking)) else: print("找到以下{}个匹配的学生:".format(len(found_students))) for i, student in enumerate(found_students): print("{:<3}{:<10}{:<10}".format(i+1, student["id"], student["name"])) def calc_stats_by_score_range(num_students, num_courses, scores): # 按成绩范围统计人数和百分比 stats_by_score_range = {} for i in range(num_courses): stats_by_score_range[i] = {"优秀": 0, "良好": 0, "中等": 0, "及格": 0, "不及格": 0} for j in range(num_students): score = scores[j][i] if score >= 90: stats_by_score_range[i]["优秀"] += 1 elif score >= 80: stats_by_score_range[i]["良好"] += 1 elif score >= 70: stats_by_score_range[i]["中等"] += 1 elif score >= 60: stats_by_score_range[i]["及格"] += 1 else: stats_by_score_range[i]["不及格"] += 1 for key in stats_by_score_range[i]: stats_by_score_range[i][key] = "{} ({:.2f}%)".format(stats_by_score_range[i][key], stats_by_score_range[i][key] / num_students * 100) return stats_by_score_range def print_score_range_stats(stats_by_score_range): # 打印成绩范围统计结果 print("成绩范围统计") print("{:<10}{:<10}{:<10}{:<10}{:<10}{:<10}".format("课程名称", "优秀", "良好", "中等", "及格", "不及格")) for i in range(num_courses): print("{:<10}{:<10}{:<10}{:<10}{:<10}{:<10}".format(course_names[i], stats_by_score_range[i]["优秀"], stats_by_score_range[i]["良好"], stats_by_score_range[i]["中等"], stats_by_score_range[i]["及格"], stats_by_score_range[i]["不及格"])) def print_all_scores(students, num_students, num_courses, course_names, scores): # 打印成绩单 print("{:<10}{:<10}{:<20}".format("学号", "姓名", "成绩")) for i, student in enumerate(students): scores_str = " ".join([str(score) for score in scores[i]]) total = sum(scores[i]) average = total / num_courses print("{:<10}{:<10}{:<20}{:<10}{:<10.2f}".format(student["id"], student["name"], scores_str, total, average)) if __name__ == "__main__": main() ```

相关推荐

某班有最多不超过30人(具体人数由键盘输入)参加期末考试,最多不超过6门(具体门数由键盘输入)。定义结构体类型描述学生信息,每个学生信息包括:学号、姓名、多门课的成绩、总成绩和平均成绩。用结构体数组作为函数参数,编程实现如下菜单驱动的学生成绩管理系统。 (1) 录入每个学生的学号、姓名和各科考试成绩。 (2) 计算每门课程的总分和平均分。 (3) 计算每个学生的总分和平均分。 (4) 按每个学生的总分由高到低排出名次表。 (5) 按学号由小到大排出成绩表。 (6) 按姓名的字典顺序排出成绩表。 (7) 按学号查询学生排名极其考试成绩。 (8) 按姓名查询学生排名极其考试成绩。 (9) 按优秀(90~100)、良好(80~90)、中等(70~80)、及格(60~70)、不及格(0~59)5个类别,对每门课程分别统计每个类别的人数以及所占的百分比。 (10) 输出每个学生的学号、姓名、各科考试成绩以及每门课程的总分和平均分。 要求程序运行后先显示如下菜单,并提示用户输入选项: 1. Input record 2. Caculate total and average score of every course 3. Caculate total and average score of every student 4. Sort in descending order by total score of every student 5. Sort in ascending order by number 6. Sort in dictionary order by name 7. Search by number 8. Search by name 9. Statistic analysis for every course 10. List record 0. Exit Please input your choice:

最新推荐

recommend-type

起点小说解锁.js

起点小说解锁.js
recommend-type

299-煤炭大数据智能分析解决方案.pptx

299-煤炭大数据智能分析解决方案.pptx
recommend-type

299-教育行业信息化与数据平台建设分享.pptx

299-教育行业信息化与数据平台建设分享.pptx
recommend-type

基于Springboot+Vue酒店客房入住管理系统-毕业源码案例设计.zip

网络技术和计算机技术发展至今,已经拥有了深厚的理论基础,并在现实中进行了充分运用,尤其是基于计算机运行的软件更是受到各界的关注。加上现在人们已经步入信息时代,所以对于信息的宣传和管理就很关键。系统化是必要的,设计网上系统不仅会节约人力和管理成本,还会安全保存庞大的数据量,对于信息的维护和检索也不需要花费很多时间,非常的便利。 网上系统是在MySQL中建立数据表保存信息,运用SpringBoot框架和Java语言编写。并按照软件设计开发流程进行设计实现。系统具备友好性且功能完善。 网上系统在让售信息规范化的同时,也能及时通过数据输入的有效性规则检测出错误数据,让数据的录入达到准确性的目的,进而提升数据的可靠性,让系统数据的错误率降至最低。 关键词:vue;MySQL;SpringBoot框架 【引流】 Java、Python、Node.js、Spring Boot、Django、Express、MySQL、PostgreSQL、MongoDB、React、Angular、Vue、Bootstrap、Material-UI、Redis、Docker、Kubernetes
recommend-type

时间复杂度的一些相关资源

时间复杂度是计算机科学中用来评估算法效率的一个重要指标。它表示了算法执行时间随输入数据规模增长而变化的趋势。当我们比较不同算法的时间复杂度时,实际上是在比较它们在不同输入规模下的执行效率。 时间复杂度通常用大O符号来表示,它描述了算法执行时间上限的增长率。例如,O(n)表示算法执行时间与输入数据规模n呈线性关系,而O(n^2)则表示算法执行时间与n的平方成正比。当n增大时,O(n^2)算法的执行时间会比O(n)算法增长得更快。 在比较时间复杂度时,我们主要关注复杂度的增长趋势,而不是具体的执行时间。这是因为不同计算机硬件、操作系统和编译器等因素都会影响算法的实际执行时间,而时间复杂度则提供了一个与具体实现无关的评估标准。 一般来说,时间复杂度越低,算法的执行效率就越高。因此,在设计和选择算法时,我们通常希望找到时间复杂度尽可能低的方案。例如,在排序算法中,冒泡排序的时间复杂度为O(n^2),而快速排序的时间复杂度在平均情况下为O(nlogn),因此在处理大规模数据时,快速排序通常比冒泡排序更高效。 总之,时间复杂度是评估算法效率的重要工具,它帮助我们了解算法在不同输入规模下的性
recommend-type

RTL8188FU-Linux-v5.7.4.2-36687.20200602.tar(20765).gz

REALTEK 8188FTV 8188eus 8188etv linux驱动程序稳定版本, 支持AP,STA 以及AP+STA 共存模式。 稳定支持linux4.0以上内核。
recommend-type

管理建模和仿真的文件

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

:YOLOv1目标检测算法:实时目标检测的先驱,开启计算机视觉新篇章

![:YOLOv1目标检测算法:实时目标检测的先驱,开启计算机视觉新篇章](https://img-blog.csdnimg.cn/img_convert/69b98e1a619b1bb3c59cf98f4e397cd2.png) # 1. 目标检测算法概述 目标检测算法是一种计算机视觉技术,用于识别和定位图像或视频中的对象。它在各种应用中至关重要,例如自动驾驶、视频监控和医疗诊断。 目标检测算法通常分为两类:两阶段算法和单阶段算法。两阶段算法,如 R-CNN 和 Fast R-CNN,首先生成候选区域,然后对每个区域进行分类和边界框回归。单阶段算法,如 YOLO 和 SSD,一次性执行检
recommend-type

ActionContext.getContext().get()代码含义

ActionContext.getContext().get() 是从当前请求的上下文对象中获取指定的属性值的代码。在ActionContext.getContext()方法的返回值上,调用get()方法可以获取当前请求中指定属性的值。 具体来说,ActionContext是Struts2框架中的一个类,它封装了当前请求的上下文信息。在这个上下文对象中,可以存储一些请求相关的属性值,比如请求参数、会话信息、请求头、应用程序上下文等等。调用ActionContext.getContext()方法可以获取当前请求的上下文对象,而调用get()方法可以获取指定属性的值。 例如,可以使用 Acti
recommend-type

c++校园超市商品信息管理系统课程设计说明书(含源代码) (2).pdf

校园超市商品信息管理系统课程设计旨在帮助学生深入理解程序设计的基础知识,同时锻炼他们的实际操作能力。通过设计和实现一个校园超市商品信息管理系统,学生掌握了如何利用计算机科学与技术知识解决实际问题的能力。在课程设计过程中,学生需要对超市商品和销售员的关系进行有效管理,使系统功能更全面、实用,从而提高用户体验和便利性。 学生在课程设计过程中展现了积极的学习态度和纪律,没有缺勤情况,演示过程流畅且作品具有很强的使用价值。设计报告完整详细,展现了对问题的深入思考和解决能力。在答辩环节中,学生能够自信地回答问题,展示出扎实的专业知识和逻辑思维能力。教师对学生的表现予以肯定,认为学生在课程设计中表现出色,值得称赞。 整个课程设计过程包括平时成绩、报告成绩和演示与答辩成绩三个部分,其中平时表现占比20%,报告成绩占比40%,演示与答辩成绩占比40%。通过这三个部分的综合评定,最终为学生总成绩提供参考。总评分以百分制计算,全面评估学生在课程设计中的各项表现,最终为学生提供综合评价和反馈意见。 通过校园超市商品信息管理系统课程设计,学生不仅提升了对程序设计基础知识的理解与应用能力,同时也增强了团队协作和沟通能力。这一过程旨在培养学生综合运用技术解决问题的能力,为其未来的专业发展打下坚实基础。学生在进行校园超市商品信息管理系统课程设计过程中,不仅获得了理论知识的提升,同时也锻炼了实践能力和创新思维,为其未来的职业发展奠定了坚实基础。 校园超市商品信息管理系统课程设计的目的在于促进学生对程序设计基础知识的深入理解与掌握,同时培养学生解决实际问题的能力。通过对系统功能和用户需求的全面考量,学生设计了一个实用、高效的校园超市商品信息管理系统,为用户提供了更便捷、更高效的管理和使用体验。 综上所述,校园超市商品信息管理系统课程设计是一项旨在提升学生综合能力和实践技能的重要教学活动。通过此次设计,学生不仅深化了对程序设计基础知识的理解,还培养了解决实际问题的能力和团队合作精神。这一过程将为学生未来的专业发展提供坚实基础,使其在实际工作中能够胜任更多挑战。