1073 多选题常见计分法 (20 分) python(测试点2分析)

1073 多选题常见计分法 (20 分) python(测试点2分析)

n, m = map(int, input().split())
option = ['a', 'b', 'c', 'd', 'e']
wrong = {}  # 存储错误选项

ans = []
for i in range(m):
    info = input().split()
    ans.append(info)

for i in range(n):
    stu = []
    score = 0.0  # 采用浮点型,否则测试点2不通过,考虑score等于0的情况
    info = input()[1:-1].split(') (')
    # 处理学生成绩
    for x in info:
        stu.append(x.split())
    for j in range(m):
        # 只比较选项部分
        stu_op = (stu[j][1:])
        ans_op = (ans[j][3:])

        # 找出不一样的选项
        for op in option:
            if op in stu_op and op in ans_op:
                ans_op.remove(op)
                stu_op.remove(op)
        if not ans_op and not stu_op:
            score += float(ans[j][0])
        elif not stu_op and ans_op:
            score += float(ans[j][0]) / 2
        # 找出错误选项,并存入字典,值对应该选项次数,键为(题号,选项)
        if ans_op:
            for k in ans_op:
                if (j + 1, k) in wrong.keys():
                    wrong[(j + 1, k)] += 1
                else:
                    wrong[(j + 1, k)] = 1
        if stu_op:
            for k in stu_op:
                if (j + 1, k) in wrong.keys():
                    wrong[(j + 1, k)] += 1
                else:
                    wrong[(j + 1, k)] = 1
    print(score)


if not wrong:
    print("Too simple")
else:
    res = []
    max_x = max(wrong.values())
    for k, v in wrong.items():
        if v == max_x:
            res.append(k)
    res.sort(key=lambda x: (x[0], x[1]))
    for i in res:
        print('{} {}-{}'.format(max_x, i[0], i[1]))

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值