用Python生成N层的杨辉三角的实现方法

【杨辉三角简介】

  杨辉三角,是二项式系数在三角形中的一种几何排列。在欧洲,这个表叫做帕斯卡三角形。

用Python生成N层的杨辉三角的实现方法_第1张图片

【代码实现】

n = eval(input("请问你想生成几层的杨辉三角呢?"))
result= []

def fun(N):   # 杨辉三角生成函数
    if N == 1:
        result.append([1])
    elif N == 2:
        result.append([1])
        result.append([1,1])
    else:
        result.append([1])
        result.append([1,1])
        for i in range(3, N+1):
            temps = []             # 用来存放第i行的所有数
            temps.append(1)        # 每行第一个数是1
            for j in range(i-2):   # 生成第i行第2个数 到 倒数第2个数
                temp = result[i-2][j] + result[i-2][j+1]
                temps.append(temp)
            temps.append(1)        # 每行倒数第一个数是1
            result.append(temps)   # 将第i行的所有数添加到列表

    return result

triangles = fun(n)
for line in triangles:
    print(line)

【结果展示】

用Python生成N层的杨辉三角的实现方法_第2张图片

【输出美化】

triangles = fun(n)
for line in range(len(triangles)):
    for x in range(len(triangles[line])):
        triangles[line][x] = str(triangles[line][x])
    triangles[line] = '   '.join(triangles[line])
    print("第{:>2}行   {:^100}".format(line+1, triangles[line]))

用Python生成N层的杨辉三角的实现方法_第3张图片

到此这篇关于用Python生成N层的杨辉三角的实现方法的文章就介绍到这了,更多相关Python 杨辉三角内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

你可能感兴趣的:(用Python生成N层的杨辉三角的实现方法)