杨辉三角c语言程序求输出n行
时间: 2023-12-07 08:39:23 浏览: 92
以下是一个C语言程序,用于输出n行杨辉三角:
```c
#include <stdio.h>
void printPascalTriangle(int n) {
int arr[n][n];
for (int i = 0; i < n; i++) {
for (int j = 0; j <= i; j++) {
if (j == 0 || j == i) {
arr[i][j] = 1;
} else {
arr[i][j] = arr[i-1][-1] + arr[i-1][j];
}
printf("%d ", arr[i][j]);
}
printf("\n");
}
}
int main() {
int n = 5; // 要输出的行数
printPascalTriangle(n);
return 0;
}
```
在上面的程序中,我们定义了一个名为`printPascalTriangle`的函数,用于生成并打印杨辉三角。该函数接受一个整数`n`作为参数,表示要生成的杨辉三角的行数。在函数中,我们定义了一个二维数组`arr`,用于存储杨辉三角的值。然后,我们使用两个嵌套的循环来计算和打印杨辉三角的值。最后,在`main`函数中,我们调用`printPascalTriangle`函数并传入要输出的行数。
相关问题
杨辉三角c语言程序打印前六行
以下是两种C语言程序打印杨辉三角前六行的方法:
方法一:
```c
#include <stdio.h>
int main() {
int a[10][10], i, j;
for (i = 0; i < 6; i++) {
for (j = 6; j >= i; j--)
printf("%2c", ' ');
for (j = 0; j <= i; j++) {
if (i == j || j == 0)
a[i][j] = 1;
else
a[i][j] = a[i - 1][j] + a[i - 1][j - 1];
printf("%4d", a[i][j]);
}
printf("\n");
}
return 0;
}
```
方法二:
```c
#include <stdio.h>
int main() {
int a[10][10];
for (int i = 0; i < 6; i++) {
a[i][0] = 1;
a[i][i] = 1;
}
for (int i = 2; i < 6; i++) {
for (int j = 1; j < i; j++) {
a[i][j] = a[i - 1][j - 1] + a[i - 1][j];
}
}
for (int i = 0; i < 6; i++) {
for (int j = 0; j <= i; j++) {
printf("%4d", a[i][j]);
}
printf("\n");
}
return 0;
}
```
n行杨辉三角c语言程序
杨辉三角是一个数学上的概念,它是一个三角形,其中第一行只有一个数1,接下来的每一行的每个数都是它左上方和右上方的两个数之和。以下是一个输出n行杨辉三角的C语言程序:
```c
#include <stdio.h>
long yanghui(int row, int column); //声明函数
int main() {
int n;
scanf("%d", &n); //输入要输出的行数
int i, j;
for (i = 1; i <= n; i++) {
for (j = 1; j <= i; j++) {
printf("%5d", yanghui(i, j)); //调用我们定义的函数
}
printf("\n");
}
return 0;
}
//定义函数,row 与 column 代表的行 与 列。
long yanghui(int row, int column) {
// 文中两个要素就在这句话体现了。
return (column == 1 || column == row) ? 1 : yanghui(row - 1, column) + yanghui(row - 1, column - 1);
}
```
阅读全文