python 格式化打印杨辉三角形 递归 (代码 + 注释)重庆邮电大学python作业

本文主要是介绍python 格式化打印杨辉三角形 递归 (代码 + 注释)重庆邮电大学python作业,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

前言

一、生成普通杨辉三角形

二、格式化打印

1. 得到最大数字位数

2. 写个函数:printf(作为我们格式化打印的方法)

总结

前言

第一篇博客,打算把自己学习中遇到的有趣的作业或者一些日常写下来,话不多说,进入正题:

题目:

首先,方便大家拿代码,直接上完全AC代码:

def triangle(n):temp = []if n == 1:temp.append(1)return templis.append(triangle(n - 1))temp.append(1)for i in range(n - 2):temp.append(lis[n - 2][i] + lis[n - 2][i + 1])temp.append(1)return tempdef printf(n,blacklen):for i in range(n):print(' ' * (blacklen * (n - i) + 1) ,end = '')for j in range(len(lis[i])):print(' ' * (blacklen - len(str(lis[i][j]))),end = '')print(lis[i][j],end = ' ' * blacklen)print()    n = int(input())
lis = []
lis.append(triangle(n))
maxNumber = lis[n - 1][n // 2]
blacklen = len(str(maxNumber))
printf(n,blacklen)

运行结果:

以下是具体实现思路:

一、生成普通杨辉三角形

我们为了格式化打印杨辉三角形,首先肯定要"生成"这个三角形,这有很多种方法,在这里,我选择使用 列表递归 去实现:

这里不去使用 "高端(我不会的数学方法)" 仅仅使用基本的杨辉三角形的规律去实现,以下是代码 + 注释:

思路:1. 因为杨辉三角是一行一行的多行结构,我们容易想到应该去使用 列表[列表[内容]] 的结构去实现

           2. 因为是递归实现,我们需要一个出口条件,这里我们将其规定为 杨辉三角形的第一行

def triangle(n):#4. 创建一个列表,它是"即将加入"lis列表的列表,即:杨辉三角型的一行,但他现在还是一个空列表,下面要进行的是对它的"加工"temp = []#5. 出口条件,所有的递归都会到这里,然后直接return 也就不会进行下面的递归,终止了所有的递归,它也是杨辉三角形的第一行if n == 1:temp.append(1)return temp#6. 如果能进行到这里,说明此时的 n 也就是现在的层数不是 1 ,所以要进行递归,递归的结果我们将它加入到lis列表中lis.append(triangle(n - 1))#7. 由杨辉三角形的特性我们可以知道它的最左边和最右边都是 1,这个直接加入即可temp.append(1)#8. 这个for循环要进行的是对一行中除了最左边和最右边的 1 的数字的填充for i in range(n - 2):# 观察可得 这一行中的每个元素都是它上一行(lis[n - 2]) 举个栗子:如果n 是第三行,那么lis[n - 2] = lis[1],也就是第二层# ...[i] 和 ...[i + 1]是 这个元素的左上和右上的两个元素temp.append(lis[n - 2][i] + lis[n - 2][i + 1])#9. 同 7 在最左边加入 1temp.append(1)#10. 返回我们已经加工成功的temp列表return temp#1. 接受输入的杨辉三角行数
n = int(input())
#2. 这是杨辉三角形的外壳,即装着列表的列表,因为列表在python是全局变量,所以我们不需要像函数中传入这个值
lis = []
#3. 运行我们的函数,设想这个函数返回了一个列表,其中是杨辉三角型的列表,我们只需要将其加入列表中即可
lis.append(triangle(n))
#打印它,让我们康康!
print(lis)

运行结果如下:

从这里,lis代表了一个杨辉三角形,但这样我们是拿不到分的,所以剩下的我们需要进行格式化打印即可

二、格式化打印

1. 得到最大数字位数

代码如下:

根据题目要求,我们格式化打印的时候需要有它的最大数字的位数,作为空格,所以,我们先设法获得它

根据杨辉三角的特性,我们只需要得到最后一行的中间的元素即可得到最大的元素,将其转化成字符串就可以拿到它的长度了!

maxNumber = lis[n - 1][n // 2]
blacklen = len(str(maxNumber))

2. 写个函数:printf(作为我们格式化打印的方法)

代码如下:

def printf(n,blacklen):for i in range(n):print(' ' * (blacklen * (n - i) + 1) ,end = '')for j in range(len(lis[i])):print(' ' * (blacklen - len(str(lis[i][j]))),end = '')print(lis[i][j],end = ' ' * blacklen)print()    

需要注意的是,这里的格式化重邮的同学们可以看看,调这个格式我眼睛要炸了(还拿尺子量),不过对于大火,这个并不是很重要,需要注意的是这个题目的数字位数是 先空格再加数字 很阴间


总结

这次的作业在递归打印这里还是挺有收获的,后面的格式化可以说是垃圾时间,只要有耐心,仔细归纳规律就行,邮耐心的同学可以自己把这个题目实现一下偶

因为我对python并不是特别熟悉,所以代码可能还有改进或者简便的方法,希望大家能多讨论,交流

这篇关于python 格式化打印杨辉三角形 递归 (代码 + 注释)重庆邮电大学python作业的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/384462

相关文章

Python脚本实现自动删除C盘临时文件夹

《Python脚本实现自动删除C盘临时文件夹》在日常使用电脑的过程中,临时文件夹往往会积累大量的无用数据,占用宝贵的磁盘空间,下面我们就来看看Python如何通过脚本实现自动删除C盘临时文件夹吧... 目录一、准备工作二、python脚本编写三、脚本解析四、运行脚本五、案例演示六、注意事项七、总结在日常使用

Python将大量遥感数据的值缩放指定倍数的方法(推荐)

《Python将大量遥感数据的值缩放指定倍数的方法(推荐)》本文介绍基于Python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处理,并将所得处理后数据保存为新的遥感影像... 本文介绍基于python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

Python进阶之Excel基本操作介绍

《Python进阶之Excel基本操作介绍》在现实中,很多工作都需要与数据打交道,Excel作为常用的数据处理工具,一直备受人们的青睐,本文主要为大家介绍了一些Python中Excel的基本操作,希望... 目录概述写入使用 xlwt使用 XlsxWriter读取修改概述在现实中,很多工作都需要与数据打交

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

利用Python编写一个简单的聊天机器人

《利用Python编写一个简单的聊天机器人》这篇文章主要为大家详细介绍了如何利用Python编写一个简单的聊天机器人,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 使用 python 编写一个简单的聊天机器人可以从最基础的逻辑开始,然后逐步加入更复杂的功能。这里我们将先实现一个简单的

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

Python实现高效地读写大型文件

《Python实现高效地读写大型文件》Python如何读写的是大型文件,有没有什么方法来提高效率呢,这篇文章就来和大家聊聊如何在Python中高效地读写大型文件,需要的可以了解下... 目录一、逐行读取大型文件二、分块读取大型文件三、使用 mmap 模块进行内存映射文件操作(适用于大文件)四、使用 pand

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一