杨辉三角
的一些理解:
感觉杨辉三角的实现至少在前两行是特殊的。在后面的几行代码中我是这样想的,可以用第n项加第n+1项。两边再加上1就可以了罢。两边如果都这么做的话可以实现对称的操作。
让我们来实现吧。在实现的过程中想套用一层循环发现难以实现,用两层试试看。
yh=[[1],[1,1]]
for i in range(2,6):
line=[1]
ls=yh[i-1]
for j in range(len(ls)-1):
line.append(ls[j]+ls[j+1])
line.append(1)
yh.append(line)
print(yh)
#打印n行的杨辉三角
a=int(input('请输入第几行'))
y=[[1],[1,1]]
for i in range(a-2):
n=y[i+1]
long=len(n)
line=[1]
for j in range(long-1):
line.append(n[j]+n[j+1])
line.append(1)
y.append(line)
print(line)
关于补零的一些想法,在杨辉三角当中,可以将左右两边当成多了一个零,在进入下一行的时候就可以看成0+1=1,同理右边也是一样,在实际写代码中,开始确实是左边多一个[0]
,右边多一个[0],但实际操作下来,左边的[0]可以