c语言杨辉三角代码对称
时间: 2023-09-24 15:08:48 浏览: 137
使用C语言编写的杨辉三角代码具备对称性,可以按以下步骤实现:
1. 首先,我们需要定义一个函数来生成杨辉三角。函数名可以是yhtri,参数line表示生成的杨辉三角的行数。
2. 在函数内部,我们定义一个二维数组arr[20][20]来存储杨辉三角的数字。初始化数组所有元素为0。
3. 使用两个循环嵌套来生成杨辉三角。外层循环控制行数,内层循环控制列数。
4. 对于每一行的第一个和最后一个数,令其等于1。
5. 对于其他位置的数,根据特点:每个数等于它上方两数之和,使用递推关系式arr[i][j] = arr[i-1][j-1] + arr[i-1][j]来计算。
6. 循环结束后,使用两个循环嵌套遍历数组arr,并使用printf函数打印杨辉三角的数字。
7. 为了使杨辉三角对称显示,我们在打印过程中使用空格来调整位置,使每行的数字左右对称。
8. 最后,从主函数main中调用yhtri函数,并通过scanf函数获取用户输入的行数。
下面是C语言实现杨辉三角对称的代码:
```c
#include <stdio.h>
void yhtri(int line) {
int i = 0, j = 0;
int arr = { 0 };
for (i = 0; i <= line - 1; i++) {
if (i == 0)
arr = 1;
else if (i == 1) {
arr = 1;
arr = 1;
} else {
for (j = 1; j < i; j++) {
arr[i][0 = 1;
arr[i][i = 1;
arr[i][j = arr[i - 1][j - 1 + arr[i - 1][j];
}
}
}
for (i = 0; i < line; i++) {
for (j = line; j > i + 1; j--) {
printf(" ");
}
for (j = 0; j <= i; j++) {
printf("%-6d", arr[i][j]);
}
printf("\n");
}
}
int main() {
int line = 0;
printf("请输入杨辉三角的行数:");
scanf("%d", &line);
yhtri(line);
return 0;
}
```
这段代码可以生成对称的杨辉三角,每行的数字左右对称显示。