第二周python牛客练习题

牛客刷题(只记录错题难题!!)

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

numba加速

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

你可能感兴趣的:(python)