用Python写一个杨辉三角函数
时间: 2024-03-28 13:16:27 浏览: 27
以下是使用Python编写的杨辉三角函数:
```python
def yanghui(n):
triangle = []
for i in range(n):
row = [1] * (i + 1)
for j in range(1, i):
row[j] = triangle[i-1][j-1] + triangle[i-1][j]
triangle.append(row)
return triangle
# 测试
result = yanghui(5)
for row in result:
print(row)
```
输出结果为:
```
[1]
[1, 1]
[1, 2, 1]
[1, 3, 3, 1]
[1, 4, 6, 4, 1]
```
其中,`n`为杨辉三角的行数,`triangle`为存储杨辉三角的列表,`row`为当前行的列表,初始化为全是1。在遍历每一行的时候,使用循环计算当前位置的值,将其存储到`row`中,最后将`row`添加到`triangle`中。
相关问题
用python写一个杨辉三角的函数
可以的,以下是用 Python 写一个杨辉三角的函数的代码:
```python
def generate_pascal_triangle(num_rows):
triangle = []
for i in range(num_rows):
row = [1] * (i + 1)
for j in range(1, i):
row[j] = triangle[i - 1][j - 1] + triangle[i - 1][j]
triangle.append(row)
return triangle
```
这个函数使用了一个二重循环,外层循环从第一行到第 num_rows 行,内层循环用来填充每一行的数字。我们通过访问上一行的数字来计算当前行的数字,这样就得到了一个杨辉三角。如果你想看到更多关于这个算法的代码实现,可以在 CSDN 上找到相关文章。
用python写一个杨辉三角形
下面是用Python写的杨辉三角形代码:
```python
# 定义一个函数,用来打印杨辉三角形
def print_triangle(n):
# 初始化二维列表
triangle = [[1] * (i + 1) for i in range(n)]
# 从第三行开始计算,每个数等于上一行对应位置和前一个位置的数之和
for i in range(2, n):
for j in range(1, i):
triangle[i][j] = triangle[i-1][j-1] + triangle[i-1][j]
# 打印杨辉三角形
for row in triangle:
print(' '.join([str(i) for i in row]).center(n*2))
# 调用函数,打印一个6层的杨辉三角形
print_triangle(6)
```
输出结果为:
```
1
1 1
1 2 1
1 3 3 1
1 4 6 4 1
1 5 10 10 5 1
```