杨辉三角解析----Python廖雪峰
图中有个很明显的特征就是两边的数字都是 1 ;
在根据图中的数字之间的连接线可以看出它的第二个特征,就是每个数字都等于它上方两个数字之和;
第三个特征,每行数字左右对称;
特征四,n 行数字有 n 个值;
其他的特征不必再看,用我们的 Python 做出这道题这些已经够用了
既然题目的那一章说的就是生成器的用法,我们就用 yield 来做:
# -*- coding: utf-8 -*-
def triangles(max):
list = [1] #定义第一个 list
n = 0 # 与 max 为一类,max 表示我们要打印多少行数据
yield list #因为第一行的 [1] 属于特殊情况 所以这里直接输出了
while n < max:
#两边用 [1] 填充 ,中间数值为之前两个数值的和
list = [1] + [list[i] + list[i+1] for i in range(n)] +[1]
yield list
n = n + 1
#函数定义完成
for t in triangles(10):
print(t)