首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
使用字典和列表型变量完成村长选举。某村有40名有选举权和被选举权的村民,名单由考生文件夹下文件name.txt给出,从这40名村民中选出一人当村长,40人的投票信息由考生文件夹下文件vote.txt给出,每行是一张选票的信息,有效票中得票最多的村民当选。
使用字典和列表型变量完成村长选举。某村有40名有选举权和被选举权的村民,名单由考生文件夹下文件name.txt给出,从这40名村民中选出一人当村长,40人的投票信息由考生文件夹下文件vote.txt给出,每行是一张选票的信息,有效票中得票最多的村民当选。
admin
2020-04-10
38
问题
使用字典和列表型变量完成村长选举。某村有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://kaotiyun.com/show/mf6p777K
本试题收录于:
二级Python题库NCRE全国计算机二级分类
0
二级Python
NCRE全国计算机二级
相关试题推荐
在VisualFoxPro的数据库表中只能有一个()。
下列选项中不属于结构化程序设计原则的是()。
使用SQL语句完成“将所有职工的年龄增加1岁”,正确的操作是()。
在SQL语句中,有可能将多个查询结果合并成一个查询结果的运算符是()。
下列关于算法复杂度叙述正确的是()。
创建一个名为student的新类,保存新类的类库名称是mylib,新类的父类是Person,正确的命令是()。
在建立表间一对多的永久联系时,主表的索引类型必须是()。
下面不属于需求分析阶段任务的是()。
对长度为n的线性表排序,在最坏情况下,比较次数不是n(n-1)/2的排序方法是()。
假设之前没有定义变量x,那么下面程序代码的输出结果是()。localx?x
随机试题
是以太山不让土壤,故能成其大;河海不择细流,故能就其深;王者不却众庶,故能明其德。
A、大量蛋白尿B、贫血C、厌食与呕吐D、肾衰竭E、呼气有尿臭味慢性肾衰竭特征性的表现是()
合成和分泌雄激素的是
与胁瘸无关的是
《民法通则》规定普通诉讼时效的期间为()年。
2009年中央1号文件指出,要鼓励和支持金融机构创新农村金融产品和金融服务,大力发展()。
给定材料【材料1】十八大以来,习近平总书记就改革创新发表了一系列重要讲座,强调创新始终是推动一个国家,一个民族向前发展的重要力量。实施创新驱动发展战略,最根本的是要增强自主创新能力,最紧迫的是要破除体制机制障碍。最大限度解放和激发科技作
《中立法》
(2008上项管)(2009下项管)在项目每个阶段结束时进行项目绩效评审是很重要的,评审的目标是______。
A—thechiefcoachB—thechiefrefereeC—thedefenderD—centreforwardE—thesecon
最新回复
(
0
)