python菜鸟学习之路

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的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值