最近在廖雪峰的官网学习python,学习到生成器部分,有一个作业是杨辉三角,在这里卡住了,有个问题实在过不去了,希望有热心的大神看到后能够指点一二, 谢谢
附:代码
'''
杨辉三角的实现
'''
#代码1
def triangles():
#计算杨辉三角的函数
ret = [1]
while True:
yield ret
ret = [sum(i) for i in zip([0]+ret,ret+[0])] #形成一个tuple(0,1)(1,0),sum(i)计算和1+0
#打印杨辉三角
n = 0
results = []
for t in triangles():
results.append(t)
n = n + 1
if n == 10:
break
for i in results:
print(i)
#代码2
def triangles(): #计算杨辉三角的函数 ret = [1] while True: yield ret for i in range(1,len(ret)): ret[i] = pre[i] + pre [i-1] ret.append(1) pre = ret[:] n = 0 results = [] for t in triangles(): results.append(t) n = n + 1 if n == 10: break for i in results: print(i)
代码1能正常计算,成功打印出杨辉三角
[1]
[1, 1]
[1, 2, 1]
[1, 3, 3, 1]
[1, 4, 6, 4, 1]
[1, 5, 10, 10, 5, 1]
[1, 6, 15, 20, 15, 6, 1]
[1, 7, 21, 35, 35, 21, 7, 1]
[1, 8, 28, 56, 70, 56, 28, 8, 1]
[1, 9, 36, 84, 126, 126, 84, 36, 9, 1]
代码2则却不行,打印结果为:
[1, 9, 36, 84, 126, 126, 84, 36, 9, 1]
[1, 9, 36, 84, 126, 126, 84, 36, 9, 1]
[1, 9, 36, 84, 126, 126, 84, 36, 9, 1]
[1, 9, 36, 84, 126, 126, 84, 36, 9, 1]
[1, 9, 36, 84, 126, 126, 84, 36, 9, 1]
[1, 9, 36, 84, 126, 126, 84, 36, 9, 1]
[1, 9, 36, 84, 126, 126, 84, 36, 9, 1]
[1, 9, 36, 84, 126, 126, 84, 36, 9, 1]
[1, 9, 36, 84, 126, 126, 84, 36, 9, 1]
[1, 9, 36, 84, 126, 126, 84, 36, 9, 1]
目前认为可能是对results赋值的问题,但是实在搞不懂,哪位热心的高手给指点一下,我的qq邮箱:8787188@qq.com
加qq指导也行,跪谢!