首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
使用字典和列表型变量完成村主任的选举。某村有40名有选举权和被选举权的村民,名单由考生文件夹下文件“name.txt”给出,从这40名村民中选出一人当村主任,40人的投票信息由考生文件夹下文件“vote.txt”给出,每行是一张选票的信息,有效票中得票最多
使用字典和列表型变量完成村主任的选举。某村有40名有选举权和被选举权的村民,名单由考生文件夹下文件“name.txt”给出,从这40名村民中选出一人当村主任,40人的投票信息由考生文件夹下文件“vote.txt”给出,每行是一张选票的信息,有效票中得票最多
admin
2021-03-17
123
问题
使用字典和列表型变量完成村主任的选举。某村有40名有选举权和被选举权的村民,名单由考生文件夹下文件“name.txt”给出,从这40名村民中选出一人当村主任,40人的投票信息由考生文件夹下文件“vote.txt”给出,每行是一张选票的信息,有效票中得票最多的村民当选。
问题1:请从“vote.txt”中筛选出无效票写入文件“vote1.txt”。有效票的含义如下:选票中只有一个名字且该名字在“name.txt”文件列表中,不是有效票的票称为无效票。
问题2:给出当选村主任的村民的名字及其得票数。
在考生文件夹下给出了程序框架文件“PY202.py”,补充代码完成程序。
试题程序:
请在________处使用一行代码或表达式替换
#注意:请不要修改其他已给出的代码
f=open("name.txt")
names=f.readlines()
f.close()
f=open("vote.txt")
votes=f.readlines()
f.close()
f=open("vote1.txt","w")
D={}
NUM=0
for vote in________(1)________:
num=len(vote.split())
if num==1 and vote in________(2)________:
D[vote[:-1]]=________(3)________+1
NUM+=1
else:
f.write(________(4)________)
f.close()
l=1ist(D.items())
l.sort(key=lambda s:s[1],________(5)________)
name=________(6)________
score=________(7)________
print("有效票数为:{}当选村主任的村民为:{},票数为:{}".format(NUM,name,score))
选项
答案
f=open("name.txt") names=f.readlines() f.close() f=open("vote.txt") votes=f.readlines() f.close() f=open("vote1.txt","w") D={} NUM=0 for vote in votes: num=len(vote.split()) if num==1 and vote in names: D[vote[:-1]]=D.get(vote[:-1],0)+1 NUM+=1 else: f.write(vote) f.close() l=list(D.items()) l.sort(key=lambda s:s[1],reverse=Ture) name=l[0][0] score=l[0][1] print("有效票数为:{}当选村主任的村民为:{},票数为:{}".format(NUM,name,score))
解析
“name.txt”文件中每行为一个村民的姓名,用readlines()函数读入所有行,以每行为元素形成列表names;“vote.txt”文件中每行为一张选票信息,用readlines()函数读入所有行,以每行为元素形成列表votes。用for循环遍历votes列表中的每个元素,并使用if进行判断。若该元素中只有一个姓名(即vote的长度为1)且该姓名也在列表names中,则为有效票,否则为无效票(将vote写入“vote1.txt”文件)。因此,第1空填入votes;第2空填入names;第4空填入vote。
若判断为有效票,就将NUM加1,统计出有效票数量。并将该元素作为字典D中的一个键,该键所对应的值为1。在后面循环中只要遍历的元素和键相同,就将该键对应的值加1。因此,第3空填入D.get(vote[:-1],0)。
l=list(D.items())表示将字典类型变成列表类型,字典中的每个键值对对应列表中的一个元组。随后,用sort()方法对列表l的元素进行排序,在参数key=lambda s:s[1]中lambda是一个隐函数,是固定写法;s表示列表中的一个元素,在这里表示一个元组,s只是临时起的一个名字,也可以使用任意的名字;s[1]表示以元组中第二个元素排序。sort()方法的第二参数表示按哪种方式排序,若为revers=True表示按降序排序;若该参数缺省或reverse=False,表示按升序排序。这里按降序排序,因此第5空填入reverse=True。
排序后,列表1中第一个元素(一个元组)中即为当选村主任的村民的姓名和选票数,name=1[0][0]表示当选村主任的村民的姓名,score=l[0][1]表示选票数。因此第6空填入l[0][0],第7空填入l[0][1]。
转载请注明原文地址:https://kaotiyun.com/show/oi6p777K
本试题收录于:
二级Python题库NCRE全国计算机二级分类
0
二级Python
NCRE全国计算机二级
相关试题推荐
打开考生文件夹下的spmt_project项目,项目中有一个名为sport_form的表单文件,表单中包括3个命令按钮。请完成如下操作:(1)编写并运行程序Four.prg。程序功能是:根据“国家”和“获奖牌情况”两个表统计并生成一个新表“假奖牌榜”,
假设使用DIMENSIONart(5)定义了一个一维数组art,正确的赋值语句是()。
在DOWHILE…ENDDO循环结构中,LOOP命令的作用是()。
设N=44,M=55,K=“N+M”,表达式1+&K的值是()。
下列选项中,不属于数据管理员(DBA)职责的是()。
下列程序段执行时在屏幕上显示的结果是()。DIMEA(3,2)FORI=1TO3FORJ=1TO2A(I,J)=I+JNEXTNEXT?A(5)
某二叉树有5个度为2的结点,则该二叉树中的叶子结点数是
设循环队列的存储空间为Q(1:35),初始状态为front=rear=35。现经过一系列入队与退队运算后,front=15,rear=15,则循环队列中的元素个数为
数据独立性是数据库技术的重要特点之一。所谓数据独立性是指()。
(1)打开考生文件夹下的表单one(如图2—31所示),编写“显示”命令按钮的Click事件代码,使表单运行时单击该命令按钮的结果是在Text1文本框中显示当前系统日期的年份(提示:通过设置文本框的Value属性实现,系统日期函数是date,年份函数是ye
随机试题
下列关于GnRH说法不正确的是:
以5’…ACTAGTCAG…3’(DNA链)为模板合成相应mRNA链的核苷酸序列应为
卫氏并殖吸虫感染人体的方式下列错误的是
患者胸胁胀痛,走窜不定,情绪不佳则加重,胸闷气短,暖气频作,舌苔薄,脉弦。其证候是()
根据《水电建设工程质量管理暂行办法》(电水农[1997]220号),建设项目的()的行政正职,对本单位的质量工作负领导责任。
外国甲公司拟出资500万美元在我国设立外商投资企业,其中通过该企业协议购买境内乙企业价值200万美元的资产,且运营该资产。如果该外商投资企业于2012年6月1日取得营业执照,外国投资者的向乙企业支付对价的下列方案中,不符合我国法律规定是()。
风景名胜资源损失的赔偿费用,必须用于风景名胜区资源的补偿、保护和建设。()
中美科学家进行的一项联合研究调查表明,在其他条件基本一致的情况下,种植抗虫转基因水稻的农户平均每季需要使用农药不到1次,而种植普通水稻的农户平均每季需要使用农药3.7次;种植转基因水稻的农户大幅度减少了农药用量,由此引起的健康问题也明显减少。转基因水稻的产
[*]
数据库技术的根本目标是要解决数据的()。
最新回复
(
0
)