执行下列代码,正确的答案是?( )
>>> l=[10,0,1,6,12,8]
>>> l.sort(key=str)
>>> l
[0,1,6,8,10,12]
[0,1,10,12,6,8]
[0,1,10,6,8,12]
[12,10,8,6,1,0]
m=[x*x for x in range(5) ]的结果的是?( )
25
16
[0, 1, 4, 9, 16]
(0, 1, 4, 9, 16)
求执行下列操作后的正确结果?( )
>>> url='www.lxsz.com'
>>> url.split()
('www.lxsz.com')
['www’,’lxsz’,’com']
['www.lxsz.com']
('www’,’lxsz’,’com')
下列声明字典的语句,错误的是?( )
d={}
d={'name':'Tom','age':20,"salary":3900}
d=dict(title='Python',author='Tom',price=59)
d=list[('name','Jerry'),('age',20)]
print(‘\x61’)的结果是?( )
\x61
‘\x61’
a
A
随机产生1-5之间的一个整数的代码是?( )
>>>import random
>>>random.randrange(1,6)
>>>import random
>>>random.randrange(1:6)
>>>import random
>>>random.randchoice(1,5)
>>>import random
>>>random.randint(1,5)
下列语句的输出结果是?( )
for i in range(6): if i%2==0: continue else: print(i,end=’,’)
1,3,5,
1,3,5
0,2,4,
0,2,4
以下列表对象的表达,非法的或者值为False的选项是?( )
[]
[None,0,’’]
[1,2,3]
[8,]!=[8]
要生成如下效果的图片,可以使用以下哪个python库?( )
jieba
math
matplotlib
wordcloud
有关jieba库的描述,错误的是?( )
jieba库的分词原理是利用英文词库,将待处理的内容与词库比对后找到最大概率的词组
jieba.lcut(s)返回的是一个列表类型
jieba.cut(s)返回的可能是一个元组类型
jieba.add_word(w)向分词词典中增加新词w
方法pop()与remove()的区别与相同点,错误的是?( )
都是删除与参数表中参数相同的元素
pop()有返回值
remove()没有返回值
pop()如果不带参数,则表示默认参数值为-1
赋值语句path='c:\abc\xyz\tag.txt',执行结果是?( )
path的值是'c:\abc\xyz\tag.txt'
path的值是'c:\bc\yz\ag.txt'
path的值是'c:\\abc\\xyz\\tag.txt'
提示出错
下列语句的输出结果是?( )
l=list(range(1,3))
print(l)
[0,1,2]
{0,1,2}
[1,2]
.{1,2}
运行下列代码,正确的结果是?( )
>>>x = set('runoob')
>>> y = set('google')
>>> x & y
{‘o’,’o’}
{'r', 'b', 'u', 'n'}
{'b', 'e', 'g', 'l', 'o', 'n', 'r', 'u'}
{'o'}
使用map函数可以实现列表数据元素类型的转换,而无需通过循环。则将列表l=['2','4','6','8']转换为列表[2,4,6,8]的函数写法为?( )
map(int,l)
list(map(int,l))
map(l,int)
list(map(l,int))
运行下列代码,正确的结果是?( )
>>>print("{:.2f}".format(3.1415926))
’3.1’
3.1
’3.14’
3.14
下列元组的声明,非法的是哪一项?( )
t=1,2,3
t=(1,2,3)
t=(1,)
t=(1)
运行下列代码的结果是?( )
import math
math.ceil(-3.3)
-4
-3
-4.0
-3.0
下列有关列表的描述,错误的是?( )
列表是包含若干元素的随机内存空间
列表是包含若干元素的有序内存空间
列表是包含若干元素的连续内存空间
列表的相邻元素之间使用逗号分隔
下列操作,正确的为哪一项?( )
>>>tuple(‘ni hao’)
>>>(‘ni’,’hao’)
>>>tuple(range(3))
>>>(0,1,2)
>>>tuple(str,range(3))
>>>(0,1,2)
>>>tuple(map(str,range(3)))
>>>(0,1,2)
下列语句的输出结果是?( )
for i in “xyz”: for j in range(3): print(i,end=’ ’) if i==”z”: break
xxxyzzz
xxxyyyz
xxxyyyzzz
xyyyzzz
下列代码的运行结果是?( )
def jishu(n): return n % 2 == 1 newlist = filter(jishu, [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]) n=list(newlist) print(n)
[2,4,6,8,10]
[1, 3, 5, 7, 9]
[1,2,3,4,5,6,7,8,9,10]
[10,9,8,7,6,5,4,3,2,1]
对于r=range(5),下列合法的方法是?( )
r[2]=8
del r[2]
r.pop()
r.count(2)
下列说法,正确的是?( )
集合类型是一个元素集合,元素之间有序
集合类型是一个元素集合,元素不能重复
集合类型是一个元素集合,元素可以重复
集合类型是一个元素集合,元素之间无序,元素类型必修相同
若d是一个字典,则max(d)是指求?( )
字典中键的最大值
字典中值的最大值
字典中键值对的最大值
字典中数字值的最大值
对于列表l=[0,1,2,3,4],all(l)的值是True,any(l)的值是False。
>>>list(zip(range(3),"abcd"))
返回[(0, 'a'), (1, 'b'), (2, 'c'),(3,’d’)]。
利用日期时间模块datetime,可以获取“今天”的日期,方法如下:
>>> import datetime
>>> t=datetime.today()。
>>>m=’\n\nnihao\t\tliping\n\n\nzhang san’
>>> m.split()
结果是:['nihao', 'liping', 'zhang san']。
列表、元组、字符串均可以用set()转换为集合,例如:>>>set((1,2,2,3,4)),结果是{1,2,2,3,4}
>>> list(enumerate(range(3)))
返回值为[(0, 0), (1, 1), (2, 2)]。
字典中的“键”不允许重复,“值”也不允许重复。in运算符的速度比列表、元组快得多。
下列两个语句的功能不可能等价:
>>> l=[x*x for x in range(6)]
>>> l=list(map(lambda x:x*x,range(6)))。
set()函数可以用于生成集合,输入的参数可以是任意组合数据类型,返回结果是一个无重复且排序任意的集合。
>>> '{0:%}'.format(3.5)返回'350.000000%';
>>>’{0:.2f}’.format(1/5)返回'0.2'。
简单去重问题:
对于给定的列表,要求对列表中每个重复元素只输出一次,请你编程完成这个任务。
例如:对于测试列表a=[11,1,14,23,11,89,14,56,89]
有如下3种算法,请你补全代码。
#方法1 a=[11,1,14,23,11,89,14,56,89] result=[] for i in a: if i not in result: ① print("方法1:",result) #方法2 a=[11,1,14,23,11,89,14,56,89] for i in [j for j in a if a.count(i)>1]: for x in range(a.count(i)-1): ② print("方法2:",a) #方法3 a=[11,1,14,23,11,89,14,56,89] i=0 while i<=len(a)-1: if a.count(a[i])>1: ③ else: ④ print("方法3:",a)
密码问题:
根据密码本和电子钥匙,破解笔记本电脑的密码。
密码本是一个非降的整数序列,电子钥匙是一个整数,得到密码的方法是在密码本中找到最接近电子钥匙的整数(如果多个符合条件,输出最小的一个)。
例如: 密码本为下面的列表
a=[1,22,43,45,45,55,60,70,89]
电子钥匙为整数44
满足条件的整数为43和45,最终的密码为43
补全下面的代码:
a=[1,22,43,45,45,55,60,70,89] #密码本 k=int(input()) #k为电子钥匙 l=0 r=8 while l+1!=r: mid=int ( ① ) if a[mid]<k: ② else: r=mid if a[r]==k: ③ if k-a[l] <= ④ : print(a[l]) else: print(⑤)
罗马数字问题:
罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。
27写做 XXVII,即为 XX + V + II 。通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如 4 不写做 IIII而是 IV。数字 1 在数字 5 的左边,所表示的数等于大数 5 减去数 1 得到的数值 4。同样地,数字 9 表示为 IX。
这个特殊的规则只适用于以下六种情况:
I 可以放在 V (5) 和 X (10) 的左边,来表示 4 和 9。
X 可以放在 L (50) 和 C (100) 的左边,来表示 40 和 90。
C 可以放在 D (500) 和 M (1000) 的左边,来表示 400 和 900。
现编写输入一个罗马数字,输出其整数结果,请编程实现上述功能,或补全代码。
例如,当输入XXII时,输出22;当输入MCMXC时,输出1990.
rmdict = {'I':1,'V':5,'X':10,'L':50,'C':100,'D':500,'M':1000} rm = list(input("请输入正确的罗马数字:")) num, prew = 0, 1 for ch in rm[::-1]: w = ① if prew > w: num = num - w else : num = num + w prew = ② print( ③ )