1.请利用filter()过滤出1~100中平方根是整数的数,即结果应该是:
[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
2.列表按照其中每一个值的绝对值排序
li = [1,-2,3,-48,78,9]
3.列表按照每一个元素的len排序
li = [(1,-2),[3],[-48,78,9],'hello world']
4.请把以下函数变成匿名函数
def add(x,y): return x+y
5.下面程序的输出结果是:
d = lambda p:p*2
t = lambda p:p*3
x = 2
x = d(x)
x = t(x)
x = d(x)
print (x)
6.现有两元组(('a'),('b')),(('c'),('d')),请使用python中匿名函数生成列表[{'a':'c'},{'b':'d'}]
# 看到匿名函数,就要想到肯定会带着考内置函数,而和匿名函数相关的内置函数只有5个:min max filter map sorted
# 排除法想到map
# 没用匿名函数
7.以下代码的输出是什么?请给出答案并解释。
def multipliers(): return [lambda x:i*x for i in range(4)] print([m(2) for m in multipliers()])
ANS:
#1 import math li=[] def f(x): return math.sqrt(x)==int(math.sqrt(x)) s=list(filter(f,range(101)))
#2 li = [1,-2,3,-48,78,9] l=sorted(li,key=abs)
#3 li = [(1,-2),[3],[-48,78,9],'hello world'] l=sorted(li,key=len) print(l)
#4 f=lambda x,y:x+y
#5 24
#6 #方法一 l=lambda x,y:[{x[0]:y[0]},{x[1]:y[1]}] #方法二 tu1 =(('a'),('b')) tu2 =(('c'),('d')) res = zip(tu1,tu2) # def func(tup): # return {tup[0]:tup[1]} ret = map(lambda tup:{tup[0]:tup[1]},res) # for i in ret: # print(i) print(list(ret)) #简化版 print(list(map(lambda tup:{tup[0]:tup[1]},zip((('a'),('b')),(('c'),('d'))))))
#7 [6,6,6,6] def multipliers(): return (lambda x:i*x for i in range(4)) # 改为生成器 print([m(2) for m in multipliers()])