赞
踩
牛客刷题(只记录错题难题!!)
1.以下程序输出为:
- def w1():
- print('正在装饰')
- def inner():
- print('正在验证权限')
-
- return inner()
-
- w1()
A. 正在装饰 正在验证权限
先调用w1()函数,执行print('正在装饰')
再定义inner()函数,返回时再调用inner()函数,和使用语句print('正在验证权限')打印
2. 有如下函数定义,执行结果正确的是?
- def dec(f):
- n = 3
- def wrapper(*args,**kw):
- return f(*args,**kw) * n
- return wrapper
-
- @dec
- def foo(n):
- return n * 2
A.foo(2)==12 B.foo(3)==12
C.foo(2)==6 B.foo(3)==6
装饰器语法,使得在不改变调用方式的情况下改变函数功能
不过不是很明白具体为什么不直接修改原函数功能
链接:装饰器
3.以下程序输出为:
- # -*- coding:utf-8 -*-
- def test(a, b, *args):
- print(a)
- print(b)
- print(args)
-
- test(11, 22, 33, 44, 55, 66, 77, 88, 99)
A.11 22 (33, 44, 55, 66, 77, 88, 99)
B.编译错误
C.运行错误
D.11 22 (11,22,33, 44, 55, 66, 77, 88, 99)
这题可以看出,对于使用*作为形参,会将后面的元素变成元组,所以args是元组
4.在Python3中,有关字符串的运算结果为:
- strs = 'I like python and java'
- one = strs.find('n')
- print(one)
- two = strs.rfind('n')
- print(two)
C.12,15
find ()从前往后,第一个目标字符下标
rfind()从前往后,最后一个目标下标
5.已知print_func.py的代码如下:
- print('Hello
- World!')
- print('__name__
- value: ', __name__)
-
- def main():
-
- print('This message is from main function')
-
- if __name__ ==
- '__main__':
-
- main()
print_module.py的代码如下:
- import print_func
- print("Done!")
运行print_module.py程序,结果是:
A. Hello World! __name__ value: print_func Done!
因为__name__只显示所在文件的文件名,如果所在文件文件名与程序名称相同则表现为__main__
6.执行下列程序,输出结果为()
- def fun(a,*,b):
-
- print(b)
-
- fun(1,2,3,4)
C.报错
当函数的的形参单独为*时,它并不属于未匹配的位置参数,而是表示后面的参数必须使用关键字参数进行匹配,所以这里会抛出异常。
所以正确的调用方式应当是fun(1,b=3)
输出为3
7.在Python3中,下列程序运行结果为:
- dicts = {}
- dicts[(1, 2)] = ({3, (4, 5)})
- print(dicts)
B.{(1, 2): {(4, 5), 3}}
首先字典的键为一个元组(1,2)这个没有问题
然后右边就是值,为一个集合!!!会自动根据hash值由大到小排序
所以右边的集合表现为{(4,5),3}
8.假设可以不考虑计算机运行资源(如内存)的限制,以下 python3 代码的预期运行结果是:()
- import math
- def sieve(size):
- sieve= [True] * size
- sieve[0] = False
- sieve[1] = False
- for i in range(2, int(math.sqrt(size)) + 1):
- k= i * 2
- while k < size:
- sieve[k] = False
- k += i
- return sum(1 for x in sieve if x)
- print(sieve(10000000000))
我投降,我怎么知道有多少个555
9.执行下列选项中的程序,输出结果为False的是()
A.
- t1 = (1,2,3)
-
- t2 = t1[:]
-
- print(t1 is t2)
B.
- lis1 = [1,2,3]
-
- lis2 = lis1[:]
-
- print(id(lis1)==id(lis2))
C.
- s1 = '123'
-
- s2 = '123'
-
- print(s1 is s2)
D.
- a = 123
-
- b = 123
-
- print(id(a) == id(b))
元组进行复制不会创建新的副本
列表进行复制会创建新的副本
10.根据以下程序,下列选项中,说法正确的是()
- class Foo():
-
- def __init__(self):
-
- pass
- def __getitem__(self,pos):
- return range(0,30,10)[pos]
-
- foo = Foo()
-
A.foo对象表现得像个序列
B.foo对象表现得像个序列
C.可以使用for i in foo:print(i)来遍历foo的元素
D. 可以使用for i in foo:print(i)来遍历foo的元素
解析:
若要表现像个序列,必须满足序列的两个方法:__len__和__getitem__,由于Foo类中没有实现__len__,因此不满足序列协议,foo对象不像序列,A错误;
foo对象没有定义__len__方法,不能使用它来查看对象个数,B错误;
对对象的迭代需要调用__iter__,如果没有定义该方法,python会调用__getitem__(),让迭代和in运算符可用,因此foo是可迭代的,C正确;
根据索引访问对象元素,会调用__getitem__(),因此D错误。
11.根据以下代码,下列选项中,说法正确的是()
- class Rectangle:
-
- __count = 0
-
- def __init__(self,width,height):
-
- Rectangle.__count += 1
-
- self.__width = width
-
- self.__height = height
-
- @property
-
- def area(self):
-
- return self.__height * self.__width
-
- rectangle = Rectangle(200,100)
-
A.创建实例对象rectangle后,可在类外使用rectangle.area()来访问area属性
B.area属性为对象的非私有属性,可以访问和修改
C.变量__count的作用是为了统计创建对象的个数
D.因为__width和__height为私有变量,所以在类外不可能访问__width和__height属性
解析:
使用@property将方法转为属性,该属性为只读属性,只可访问但是不可以修改,使用对象.方法名来访问该属性,但是方法不能再加小括号,故AB选项说法均错误;
12.在Python3中,程序运行结果为:
- lists = [1, 1, 2, 3, 4, 5, 6]
- lists.remove(1)
- lists.extend([7,8,9])
- print(lists)
C.[1,2,3,4,5,6,7,8,9]
remove()函数用于移除列表中某个值的第一个匹配项。
extend函数是将新列表值依次添加到老列表末尾
13.在Python3中,下列答案正确的是:
- lists = [1, 2, 2, 3, 4, 5]
- print(lists.index(2))
A.1
解析:
在Python3中,list.index(obj)表示从列表中找出某个值第一个匹配项的索引位置,且列表的索引是从 0 开始的,所以返回 2 所在的第一个索引为 1
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。