首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
使用字典和列表型变量完成村长选举。某村有40名有选举权和被选举权的村民,名单由考生文件夹下文件name.txt给出,从这40名村民中选出一人当村长,40人的投票信息由考生文件夹下文件vote.txt给出,每行是一张选票的信息,有效票中得票最多的村民当选。
使用字典和列表型变量完成村长选举。某村有40名有选举权和被选举权的村民,名单由考生文件夹下文件name.txt给出,从这40名村民中选出一人当村长,40人的投票信息由考生文件夹下文件vote.txt给出,每行是一张选票的信息,有效票中得票最多的村民当选。
admin
2020-04-10
36
问题
使用字典和列表型变量完成村长选举。某村有40名有选举权和被选举权的村民,名单由考生文件夹下文件name.txt给出,从这40名村民中选出一人当村长,40人的投票信息由考生文件夹下文件vote.txt给出,每行是一张选票的信息,有效票中得票最多的村民当选。
问题1:请从vote.txt中筛选出无效票写入文件votel.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(”votel.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()
1=list(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(”votel.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=True) 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写入到””votel.txt”文件中)。因此,第一空填入:votes;第二空填入:names;第四空填入:vote。
若判断为有效票,就将NUM加1,统计出有效票数量;并将该元素作为字典D中的一个键,该键所对应的值为1,在后面循环中只要遍历的元素和键相同,就将该键对应的值加1。因此,第三空填入:D.get(vote[:一1],0)。
l=list(D.items())表示将字典类型变成列表类型,字典中的每个键值对对应列表中的一个元组。随后,对列表l中的元素进行排序,用到sort()方法,参数”key=lambda s:s[1]”中lambda是一个隐函数,是固定写法,不能写成别的单词;s表示列表中的一个元素,在这里表示一个元组,s只是临时起的一个名字,也可以使用任意的名字;s[1]表示以元组中第二个元素排序。sort()方法的第二参数表示是按哪种方式排序,若为”reverse=True”表示按降序排序;若该参数缺省或”reverse=False”,表示按升序排序。这里我们按降序排序,因此第五空填入:reverse=True。
排序后,列表l中第一个元素(一个元组)中即为当选村长姓名和选票数,name=l[0][0]表示当选村长姓名,score=l[0][1]表示选票数。
转载请注明原文地址:https://www.kaotiyun.com/show/mf6p777K
本试题收录于:
二级Python题库NCRE全国计算机二级分类
0
二级Python
NCRE全国计算机二级
相关试题推荐
在SQL语句中,有可能将多个查询结果合并成一个查询结果的运算符是()。
项目文件中的“文本文件”包含在()。
创建一个名为student的新类,保存新类的类库名称是mylib,新类的父类是Person,正确的命令是()。
以下有关SELECT短语的叙述中错误的是()。
一棵二叉树共有25个结点,其中5个是叶子结点,则度为1的结点数为()。
对长度为n的线性表排序,在最坏情况下,比较次数不是n(n-1)/2的排序方法是()。
表单里有一个选项按钮组,包含两个选项按钮Option1和Option2。假设Option2没有设置Click事件代码,而Option1以及选项按钮组和表单都设置了Click事件代码。那么当表单运行时,如果用户单击Option2,系统将()。
假设之前没有定义变量x,那么下面程序代码的输出结果是()。privatex?x
要清除顶层表单中调用的菜单文件,一般在表单的哪个事件中编写程序代码()。
查询设计器中的“筛选”选项卡的作用是
随机试题
尼可刹米没有下列哪一种作用
环绕口唇的经脉有
下列关于生长发育一般规律的论述,哪项是错误的
某男,20岁,足底刺伤后发生破伤风,频繁抽搐,治疗的最重要环节是
(2009年)正弦交流电压的波形图如图8—21所示,该电压的时域解析表达式为()。
违约责任的承担方式有()。
按照国家政策规定,投资项目资本金的出资方式不包括()。
工人必需消耗的工作时间中,熟悉图纸、准备相应的工具、事后清理场地等,属于()。
当员工不理解工作内容时就会产生()
在整型指针变量ptr1、ptr12的定义中,错误的是______。
最新回复
(
0
)