栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

杨辉三角形(Python)

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

杨辉三角形(Python)

杨辉三角形的规则就是每行的第一个数字和最后一个数字为1之外,其余每个数字等于上一行对应两个数字的和。

1、使用二维数组实现
def triangle(row):
	result = []
	for i in range(row):
		if i == 0: # 第一行
			result.append([1])
		elif i == 1: # 第二行
			result.append([1,1])
		else:
			y = []
			for j in range(i+1): # 第i行有i+1个数
				if j == 0 or j == i:
					y.append(1) # 就是每行的第一个元素 和 最后一个元素 为1
				else:
					y.append(result[i-1][j-1]+result[i-1][j])
			result.append(y)
	return result

if __name__ == "__main__":
	result = triangle(6)
	for row in result:
		print(row)

结果如下:

2、生成器实现
def triangle():
	result = [1]
	while True:
		yield result
		result = [1] + [x+y for x,y in zip(result[:-1],result[1:])] + [1]
if __name__ == "__main__":
	n = 0
	for i in triangle():
		print(i)
		n += 1
		if n == 10:
			break

其结果如下:

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/488233.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号