(python3)1080. MOOC期终成绩 (19分)——2017-12考题
来源:互联网 发布:燕十八php教程 网盘 编辑:程序博客网 时间:2024/05/29 16:20
题目赘述:
对于在中国大学MOOC(http://www.icourse163.org/)学习“数据结构”课程的学生,想要获得一张合格证书,必须首先获得不少于200分的在线编程作业分,然后总评获得不少于60分(满分100)。总评成绩的计算公式为 G = (G期中x 40% + G期末x 60%),如果 G期中 > G期末;否则总评 G 就是 G期末。这里 G期中 和 G期末 分别为学生的期中和期末成绩。
现在的问题是,每次考试都产生一张独立的成绩单。本题就请你编写程序,把不同的成绩单合为一张。
输入格式:
输入在第一行给出3个整数,分别是 P(做了在线编程作业的学生数)、M(参加了期中考试的学生数)、N(参加了期末考试的学生数)。每个数都不超过10000。
接下来有三块输入。第一块包含 P 个在线编程成绩 G编程;第二块包含 M 个期中考试成绩 G期中;第三块包含 N 个期末考试成绩 G期末。每个成绩占一行,格式为:学生学号 分数。其中学生学号为不超过20个字符的英文字母和数字;分数是非负整数(编程总分最高为900分,期中和期末的最高分为100分)。
输出格式:
打印出获得合格证书的学生名单。每个学生占一行,格式为:
学生学号 G编程 G期中 G期末 G
如果有的成绩不存在(例如某人没参加期中考试),则在相应的位置输出“-1”。输出顺序为按照总评分数(四舍五入精确到整数)递减。若有并列,则按学号递增。题目保证学号没有重复,且至少存在1个合格的学生。
输入样例:6 6 701234 880a1903 199ydjh2 200wehu8 300dx86w 220missing 400ydhfu77 99wehu8 55ydjh2 98dx86w 88a1903 8601234 39ydhfu77 88a1903 6601234 58wehu8 84ydjh2 82missing 99dx86w 81输出样例:
missing 400 -1 99 99ydjh2 200 98 82 88dx86w 220 88 81 84wehu8 300 55 84 84题目解析:
题目不难理解,又是一个统计类型的题,统计学生和成绩。关键在于构造合理的思路和数据结构。
代码如下:
p,m,n = list(map(int,input().split()))ans ={}pass_name=[]for i in range(p): id,score = input().split() if int(score) >= 200: ans[id] = [score, 0, 0]for i in range(m): id,score = input().split() if id in ans.keys(): ans[id][1] = scorefor i in range(n): id, score = input().split() if id in ans.keys(): ans[id][2] = scorefor id,scores in ans.items(): mid = int(scores[1]) fin = int(scores[2]) tol = 0.6*fin + 0.4*mid if mid>fin else fin mid = -1 if mid == 0 else mid if tol >= 60: pass_name.append([id,scores[0],mid,fin,round(tol)])out = sorted(pass_name,key = lambda x:[-x[4],x[0]])for s in out: print(s[0],s[1],s[2],s[3],s[4])
以编程成绩为第一门槛,筛选出可以进入总评阶段的学生名单,使用字典结构(十分方便,谁用谁知道);
然后遍历期中成绩和期末成绩,将进入门槛的学生的成绩添加进去(大概只有字典比较方便);
最后处理字典中每一项,计算总评成绩,筛选合格同学,最后输出。
需要说明的是,一,合理的数据结构的选择很重要;二,该题最后一个测试点超时(6分啊!),不知如何改进算法,还请大佬指点!
- (python3)1080. MOOC期终成绩 (19分)——2017-12考题
- 1080. MOOC期终成绩 (25)
- (python3)1077. 互评成绩计算 (20分)——2017-12考题
- PAT 乙级 1080. MOOC期终成绩 (25)
- PTA MOOC期终成绩
- 1080. MOOC期终成绩 (未拿满分)
- 1080. MOOC期终成绩 (25) PAT乙级真题
- Map 用法 PAT 1080. MOOC期终成绩 (25)
- (python3)1076. Wifi密码 (15分)——2017-12考题
- (python3)1078. 字符串压缩与解压 (20分)——2017-12考题
- java练习——计算平均分总成绩
- MOOC浙大数据结构 — 07-图4 哈利·波特的考试 (25分)
- MOOC浙大数据结构 — 08-图8 How Long Does It Take (25分)
- MOOC浙大数据结构 — 03-树2 List Leaves (25分)
- C#—考题字符串2
- python3之1013.数素数 (19分)
- 11 互评成绩 (25分)——double类型的快排函数
- 软件工程——结合软考题
- Tomcat Web应用配置
- 本地Mac利用N切换Node版本
- 数据结构总结之线段树
- MemCache详细解读
- valgrind
- (python3)1080. MOOC期终成绩 (19分)——2017-12考题
- Memcache工作原理总结
- Android Fresco的简单使用
- 最近以来学习thinkphp的总结
- 关于QtCharts中的映射器与模型的使用
- Memcached, Redis, MongoDB区别
- sql server 2008安装
- 职业生涯规划
- JAVA 集合 List