杨辉三角:每个数等于它上方两数之和。空位看作0
答案:
#定义函数
def triangles():
L = [1] // L是只含1的list(列表)
yield L
// generator的函数遇到yield语句返回,再次执行时从上次返回的yield语句处继续执行。
while True: //def中不设限的循环
L = [v+w for v,w in zip([0]+L,L+[0])] //列表生成式、zip函数 → 错位加【详解】
yield L
#打印三角
for i,lst in enumerate( triangles() ):
//for...in循环:依次把list或tuple中的每个元素迭代出来
//enumerate():枚举。遍历一个集合对象,它在遍历的同时还可以得到当前元素的索引位置
print(lst)
if i>=10: // python i 自加,打印完索引i=10对应列表,结束。共11个列表,11行
break
单句分析:
L = [v+w for v,w in zip([0]+L,L+[0])] //列表生成式、zip函数 → 错位加【详讲】
- 列表生成式
L = [v+w],v和w来源于zip函数的生成结果
- zip函数
对应参数打包成元组(tuple,“ 不能更改的list ” ),元组构成list。在这里,两个列表变为一个。