c语言杨辉三角如何输出两组结果
时间: 2024-10-21 17:12:49 浏览: 30
杨辉三角是一个经典的组合数学问题,通常用动态规划的方法来解决,特别是在递归算法中。C语言中输出杨辉三角,我们可以设计一个二维数组来存储每一行的数据,并采用嵌套循环的方式逐层打印。
以下是简单的步骤和示例代码:
1. 初始化一个大小为(n+1) * (n+1)的二维数组,其中n是你想要输出的行数。
2. 杨辉三角的第一行和第一列始终是1。
3. 使用两个嵌套循环,外层控制行,内层控制列。对于除了第一行和第一列以外的每个位置(i, j),其值等于上一行的i-1个元素乘以前一行的j个元素除以(i+j-1)。
4. 输出的时候,除了边界条件,其他位置的值需要同时输出它的左邻和上邻。
下面是一个简化的C语言函数,用于输出前n行的杨辉三角:
```c
#include <stdio.h>
void printPascalTriangle(int n) {
int triangle[n + 1][n + 1];
// 初始化边界值
for (int i = 0; i <= n; ++i) {
triangle[i][0] = triangle[i][i] = 1;
}
// 打印三角形
for (int i = 0; i <= n; ++i) {
for (int j = 1; j < i; ++j) {
printf("%d ", triangle[i][j]);
}
printf("%d\n", triangle[i][i]);
}
}
int main() {
int rows = 5; // 可以替换为你想要的任意行数
printPascalTriangle(rows);
return 0;
}
```
阅读全文