day3
递归函数
def fact(n):
if n==1:
return 1
return n * fact(n - 1)
注意,当n特别大时会栈溢出。Python标准的解释器没有针对尾递归做优化,任何递归函数都存在栈溢出的问题。
今天不是很开心,不知道自己以后会不会学的很好。
迭代:默认情况下,dict迭代的是key。如果要迭代value,可以用for value in d.values()
,如果要同时迭代key和value,可以用for k, v in d.items()
。如何判断一个对象是可迭代对象呢?方法是通过collections模块的Iterable类型判断
列表生成式:列表生成式则可以用一行语句代替循环生成上面的list
>>> [x * x for x in range(1, 11) if x % 2 == 0] [4, 16, 36, 64, 100]
还可以使用两层循环,可以生成全排列:
>>> [m + n for m in 'ABC' for n in 'XYZ'] ['AX', 'AY', 'AZ', 'BX', 'BY', 'BZ', 'CX', 'CY', 'CZ']
这也是6的。