Python - 杨辉三角

分享一个大牛的人工智能教程。零基础!通俗易懂!风趣幽默!希望你也加入到人工智能的队伍中来!请点击人工智能教程

#!/usr/bin/env python3
# -*- coding: utf-8 -*-

# Triangle generator
def generate_triangle():
    li = [1]
    while True:
        yield li
        li = [1] + [li[i] + li[i + 1] for i in range(0, len(li) - 1)] + [1]


# Get triangles with rank = r
def get_triangles(r):
    triangles = [[1]]
    i = 0
    for tri in generate_triangle():
        i += 1
        # Continue the loop since triangles is already initialized with [[1]]
        if i == 1:
            continue
        triangles.append(tri)
        if i == r:
            return triangles


# Print triangles with well format
def print_triangles(triangles, width):
    print_width = len(triangles[:]) * width
    for triangle in triangles:
        triangle_line = []
        for triangle_content in triangle:
            triangle_line.append('{0:^{1}}'.format(str(triangle_content), width))
        print('{0:^{1}}'.format(''.join(triangle_line), print_width))


TRIANGLES = get_triangles(10)
print_triangles(TRIANGLES, len(TRIANGLES[:-1][len(TRIANGLES[:-1]) // 2]) + 1)

print('开始测试')
# 期待输出:
# [1]
# [1, 1]
# [1, 2, 1]
# [1, 3, 3, 1]
# [1, 4, 6, 4, 1]
# [1, 5, 10, 10, 5, 1]
# [1, 6, 15, 20, 15, 6, 1]
# [1, 7, 21, 35, 35, 21, 7, 1]
# [1, 8, 28, 56, 70, 56, 28, 8, 1]
# [1, 9, 36, 84, 126, 126, 84, 36, 9, 1]
LAYER = 0
RESULTS = []
for t in generate_triangle():
    print(t)
    RESULTS.append(t)
    LAYER = LAYER + 1
    if LAYER == 10:
        break
if RESULTS == [
    [1],
    [1, 1],
    [1, 2, 1],
    [1, 3, 3, 1],
    [1, 4, 6, 4, 1],
    [1, 5, 10, 10, 5, 1],
    [1, 6, 15, 20, 15, 6, 1],
    [1, 7, 21, 35, 35, 21, 7, 1],
    [1, 8, 28, 56, 70, 56, 28, 8, 1],
    [1, 9, 36, 84, 126, 126, 84, 36, 9, 1]
]:
    print('测试通过!')
else:
    print('测试失败!')

# Output:
'''
                             1                              
                          1     1                           
                       1     2     1                        
                    1     3     3     1                     
                 1     4     6     4     1                  
              1     5     10    10    5     1               
           1     6     15    20    15    6     1            
        1     7     21    35    35    21    7     1         
     1     8     28    56    70    56    28    8     1      
  1     9     36    84   126   126    84    36    9     1   
开始测试
[1]
[1, 1]
[1, 2, 1]
[1, 3, 3, 1]
[1, 4, 6, 4, 1]
[1, 5, 10, 10, 5, 1]
[1, 6, 15, 20, 15, 6, 1]
[1, 7, 21, 35, 35, 21, 7, 1]
[1, 8, 28, 56, 70, 56, 28, 8, 1]
[1, 9, 36, 84, 126, 126, 84, 36, 9, 1]
测试通过!

'''

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值