Py小郑 2022-01-29 10:22 采纳率: 97.2%
浏览 63
已结题

Python如何打印杨辉三角形

img


输出如图所示(虚线不要,虚线只是用来描述轮廓线) 请问该如何编写代码?感觉好难= =
我感觉好像要用到居中

  • 写回答

1条回答 默认 最新

  • LYSnowy 2022-01-29 10:53
    关注
    
    def Traingle(x):
        '''定义杨辉三角的函数,即下一行的第N个元素,是本行的第N个元素和第N-2个元素的和,最后返回一个列表'''
        x = int(x)
        Traingle_list = []
        if x == 1:
            Traingle_list = [1]
        elif x == 2:
            Traingle_list = [1,1]
        else:
            Traingle_list_temp = Traingle(x-1)#获取上一行三角列表
            Traingle_list = [1,1]
            temp = 1
            while temp <= x-2:
                Traingle_list.insert(temp,Traingle_list_temp[temp]+Traingle_list_temp[temp-1])
                temp += 1
    
        return Traingle_list
    
    
    def PrintTringle(x):
        n = 1
        x = int(x)
        # 获取最大的元素,判断列表最大的元素的长度
        if x % 2 == 0:
            max_item = Traingle(x)[int(x/2)]
        else:
            max_item = Traingle(x)[int((x+1)/2)]
        max_length = len(str(max_item))
        while n <= x :
            list = Traingle(n)
            string = ''
            tem = 0
            # 对每一列杨辉三角进行处理,转化成为字符串,拼接
            while tem < len(list):
                if tem == 0:
                    string = str(list[tem]).center(max_length)
                else:
                    string = string + ' ' + str(list[tem]).center(max_length)
                tem += 1
            # 打印处理,每一列的元素有N个,空格用N+1
            print(string.center((max_length+1)*x-1))
            n += 1
    
    
    if __name__ == '__main__':
        PrintTringle(10)
    

    img

    不用居中,输出空格就可以

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

    报告相同问题?

    问题事件

    • 系统已结题 2月6日
    • 已采纳回答 1月29日
    • 修改了问题 1月29日
    • 修改了问题 1月29日
    • 展开全部

    悬赏问题

    • ¥15 爬虫爬取安居客新房信息
    • ¥15 php5.3内存泄露
    • ¥15 DigSilent如何复制复合模型到自己案例?
    • ¥15 求日版华为b610s-77a 官方公版固件,有偿
    • ¥15 关于#java#的问题,请各位专家解答!(相关搜索:java程序)
    • ¥15 linux tsi721的驱动编译后 insmod 提示 报错
    • ¥20 multisim测数据
    • ¥15 求无向连通网的所有不同构的最小生成树
    • ¥15 模拟器的framebuffer问题
    • ¥15 opencv检测轮廓问题