当前位置:
首页 > Python基础教程 >
-
python打印杨辉三角形(Pascal's Triangle)
杨辉三角形(Pascal's Triangle)是一个在数学上非常常见的三角形数表,它的每一行都是上一行相邻两项的和。在Python中,我们可以使用列表来生成和打印杨辉三角形。
下面是一个简单的Python函数,用于打印指定行数的杨辉三角形:
运行上述代码将输出5行的杨辉三角形:
在上面的代码中,我们首先创建了一个只包含第一行(一个包含单个元素1的列表)的杨辉三角形列表。然后,我们通过迭代来构建剩余的行。在每一行中,我们都使用上一行的元素来计算当前行的元素,并将新行添加到三角形列表中。最后,我们遍历三角形列表并打印每一行。
最后,如果你对vb.net语言还有任何疑问或者需要进一步的帮助,请访问https://www.xin3721.com 本站原创,转载请注明出处:https://www.xin3721.com/Python/python49267.html
下面是一个简单的Python函数,用于打印指定行数的杨辉三角形:
def print_pascal_triangle(num_rows):
# 初始化杨辉三角形的第一行
triangle = [[1]]
for i in range(1, num_rows):
# 初始化当前行的第一个元素
prev_row = triangle[i - 1]
curr_row = [1]
# 根据上一行计算当前行的元素
for j in range(1, i):
curr_row.append(prev_row[j - 1] + prev_row[j])
# 添加当前行的最后一个元素
curr_row.append(1)
# 将当前行添加到三角形中
triangle.append(curr_row)
# 打印杨辉三角形
for row in triangle:
print(' '.join(map(str, row)))
# 测试函数
print_pascal_triangle(5)
# 初始化杨辉三角形的第一行
triangle = [[1]]
for i in range(1, num_rows):
# 初始化当前行的第一个元素
prev_row = triangle[i - 1]
curr_row = [1]
# 根据上一行计算当前行的元素
for j in range(1, i):
curr_row.append(prev_row[j - 1] + prev_row[j])
# 添加当前行的最后一个元素
curr_row.append(1)
# 将当前行添加到三角形中
triangle.append(curr_row)
# 打印杨辉三角形
for row in triangle:
print(' '.join(map(str, row)))
# 测试函数
print_pascal_triangle(5)
运行上述代码将输出5行的杨辉三角形:
1
1 1
1 2 1
1 3 3 1
1 4 6 4 1
1 1
1 2 1
1 3 3 1
1 4 6 4 1
在上面的代码中,我们首先创建了一个只包含第一行(一个包含单个元素1的列表)的杨辉三角形列表。然后,我们通过迭代来构建剩余的行。在每一行中,我们都使用上一行的元素来计算当前行的元素,并将新行添加到三角形列表中。最后,我们遍历三角形列表并打印每一行。
最后,如果你对vb.net语言还有任何疑问或者需要进一步的帮助,请访问https://www.xin3721.com 本站原创,转载请注明出处:https://www.xin3721.com/Python/python49267.html
栏目列表
最新更新
使用Python发送电子邮件
SpringBoot中Session的使用及说明
springboot后台session的存储与取出方式
Springboot使用ResponseBody汉字返回问号问题
Springboot下载excel文件中文名乱码问题及解
SpringBoot整合weixin-java-pay实现微信小程序支
Java Socket报错打开文件过多的问题
使用nacos实现自定义文本配置的实时刷新
解决springboot文件上传提示临时文件夹不存
Springboot如何使用外部yml启动
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
uniapp/H5 获取手机桌面壁纸 (静态壁纸)
[前端] DNS解析与优化
为什么在js中需要添加addEventListener()?
JS模块化系统
js通过Object.defineProperty() 定义和控制对象
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比