昼伏君 2018-12-03 04:23 采纳率: 100%
浏览 753
已采纳

一个杨辉三角的生成器问题

杨辉三角如下:

[1]
[1, 1]
[1, 2, 1]
[1, 3, 3, 1]
[1, 4, 6, 4, 1]
[1, 5, 10, 10, 5, 1]

实现一个生成器,不断输出下一行的列表,实现代码如下:

def triangles():
     N = [1]
     while True:
         yield N
         N.append(0)
         N = [N[i-1] + N[i] for i in range(len(N))]

n = 0
results = []
for t in triangles():
    print(t)
    results.append(t)
    n = n + 1
    if n == 5:
        break

print(results)


运行结果:
图片说明

results.append(t)语句里的t和print(t)里的t应该一样呀,为何results中的列表末项会多一个零?

  • 写回答

1条回答 默认 最新

  • 小小月牙 2018-12-03 13:00
    关注

    你好,python中所有东西都可以视为对象,希望对你有所帮助

    yield N                                        #返回一个列表对象
    N.append(0)                                    #对当前对象添加 0 元素
    N = [N[i-1] + N[i] for i in range(len(N))]     #N变量重新绑定对象      
    

    这是由于你使用的是append()方法添加的 0 ,results里的上一个元素和你求下一行时 (N.append(0))的N绑定的对象是同一个,所以会改变;
    打印出来的是改变之前的,所以看不出,从results最后一个元素没有加0就可以看出来,那是因为还没有开始求下一行数。
    解决办法:
    yield N

    N = N + [0] #这里重新生成了一个列表对象,用N重新绑定
    N = [N[i-1] + N[i] for i in range(len(N))]

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 乌班图ip地址配置及远程SSH
  • ¥15 怎么让点阵屏显示静态爱心,用keiluVision5写出让点阵屏显示静态爱心的代码,越快越好
  • ¥15 PSPICE制作一个加法器
  • ¥15 javaweb项目无法正常跳转
  • ¥15 VMBox虚拟机无法访问
  • ¥15 skd显示找不到头文件
  • ¥15 机器视觉中图片中长度与真实长度的关系
  • ¥15 fastreport table 怎么只让每页的最下面和最顶部有横线
  • ¥15 java 的protected权限 ,问题在注释里
  • ¥15 这个是哪里有问题啊?