用python写出杨辉三角表达式

杨辉三角的规律如下:
在这里插入图片描述
由上图可知,从第三行开始,除了首尾的1以外,每个数字等于上一行的左右两个数字之和,第一行我们可以假设为1,但是第二行的规律不容易写,我们可以试着将杨辉三角“补全”,如下图所示:
在这里插入图片描述
这样,从第二行开始,原列表的每个数都是上一列的左右两个数相加之和,由此可得:
第一行:[0, 1, 0]
第二行:[0, 1, 1, 0]
第三行:[0, 1, 2, 1, 0]
第四行:[0, 1, 3, 3, 1, 0]

假设第一行为a,a =[0, 1, 0]
第二行可以表示为:[0] + [a[0] + a[1]] + [a[1] + a[2]] + [0]
第三行可以表示为:[0] + [a[0] + a[1]] + [a[1] + a[2]] + [a[2]+ [3]] + [0]

由以上可以得到表达式:[0] + [a[i] + a[i+1] for i in range(x)] + [0],现在来找x的表达式,我们可以看到,第二行的x为2,第三行的x为3,可以用上一行的列表元素数量-1来表示,即:len(a) -1,由此可得:
[0] + [a[i] + a[i+1] for i in range(len(a) - 1)] + [0]

但我们要清楚,补0的目的只是为了得到表达式,本来的杨辉三角列表并没有0,我们可以在获取表达式之后就将其重新赋值替换掉:

...
a = [1] #先假设第一行的元素
while Ture:
	yield a  #这里用到了生成器
	a = [0] + a + [0]  #为了获得下面的表达式进行补0的操作
	a =  [a[i] + a[i+1] for i in range(len(a) - 1)]   #获取完表达式后可以重新赋值替换掉,得到的就会是两个0中间的列表元素

到此,我们可以尝试去获得杨辉三角的前20行元素:
在这里插入图片描述
得到的结果如下:
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值