重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
题目:
思路
主要在于看懂题目
需要注意的地方:
输出错得最多的题目选项的信息:指的是所有题目的所有选项被漏选和错误次数之和最多的选项,而不是每道题有几个学生做错。
例如
对于题目1 正确选项是(a,c)
学生1的选项为:a,d
学生2的选项为:a,b,c
学生3的选项为: a,d
学生4的选项为: b,c
对于此例来说:每个选项分别被漏选和错选的次数为:
a:1
b:1
c:2
d:2
此例错得最多的题目选项应该是c,d
代码
#对不是完全正确的答案的选项进行漏选和错选次数的统计
def err_answer_count(temp,pro_corr_item,stu_answer):
corr_item_temp = pro_corr_item
for err in stu_answer:
if err not in pro_corr_item:
temp[ord(err) - ord('a')] = temp[ord(err) - ord('a')] + 1
else:
corr_item_temp.remove(err)
for remind in corr_item_temp: # 不得分的错误答案中对正确答案漏选选项的统计
temp[ord(remind) - ord('a')] = temp[ord(remind) - ord('a')] + 1
return temp
N,M= map(int, input().split())
item_msg = [] #存储题目信息
for i in range(M):
item_msg.append(list(input().split()))
err_pro_sel ={} #每道题每个选项漏选或错选的总次数
for i in range(M):
err_pro_sel[i]=[0]*5
for i in range(N):
stu_msg = list(input().split(') ('))
stu_msg[0]=stu_msg[0].replace('(','')
stu_msg[-1]=stu_msg[-1].replace(')','')
stu_score = 0.0
pro_th=0 #记录题的序号
for stu_item, pro_item in zip(stu_msg, item_msg):
stu_item=list(stu_item.split())
pro_score = int(pro_item[0])
pro_all_num = int(pro_item[1]) #所有选项的数目
pro_corre_num = int(pro_item[2]) #正确答案的数目
pro_corr_item = pro_item[3:] #正确答案
if int(stu_item[0])<= pro_corre_num:
is_true = 0
for it in stu_item[1:]:
if it not in pro_corr_item: #错误
is_true = -1
break
is_true = is_true + 1
if is_true != -1:
if is_true == pro_corre_num: #全对
stu_score = stu_score + pro_score
else: #漏选
temp = err_pro_sel[pro_th]
err_pro_sel[pro_th] = err_answer_count(temp,pro_corr_item,stu_item[1:])
stu_score = stu_score + pro_score / 2.0
else:
# 分别将选错的选项进行+1统计
temp = err_pro_sel[pro_th]
err_pro_sel[pro_th]=err_answer_count(temp,pro_corr_item,stu_item[1:])
else:
#分别将选错的选项进行+1统计
temp=err_pro_sel[pro_th]
err_pro_sel[pro_th]=err_answer_count(temp,pro_corr_item,stu_item[1:])
pro_th=pro_th+1
print('{:.1f}'.format(stu_score))
max_pro_item=0
for i in err_pro_sel:
for j in range(len(err_pro_sel[i])):
if err_pro_sel[i][j]>max_pro_item:
max_pro_item=err_pro_sel[i][j]
if max_pro_item==0:
print("Too simple")
else:
for i in err_pro_sel:
for j in range(len(err_pro_sel[i])):
if err_pro_sel[i][j] == max_pro_item:
print(f"{max_pro_item} {i+1}-{chr(ord('a')+j)}")
你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧