杨辉三角的两种解法

杨辉三角的两种解法

在学习廖雪峰python教程中,“高级特性==>生成器”遇到杨辉三角的练习题,比较有意思。记录下掌握的两种解法。


1,前后补0

思路:上一行前后补0,每两个元素相加得到该行数列。


def triangles():
    L = [1]
    while True:
        yield L
        L = [sum(i) for i in zip([0]+L, L+[0])]
        
n = 0
results = []
for t in triangles():
    results.append(t)
    n = n + 1
    if n == 10:
        break

for t in results:
    print(t)

2,后补0

思路:上一行后补0。
注意:在这里使用L[:],如果使用L会出错。由于Python是动态语言,在一次循环中使用L.append(0),yield L会出现L列表后面加0的情况。


def triangles():
    L = [1]
    while True:
        yield L[:]
        L.append(0)
        L = [L[i-1] + L[i] for i in range(len(L))]
                
n = 0
results = []
for t in triangles():
    results.append(t)
    n = n + 1
    if n == 10:
        break

for t in results:
    print(t)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值