C语言,二维数组:输入一个正整数,输出指定行数的杨辉三角。 输入格式: 一个不大于20的正整数 输出格式: 对应输入值行数的杨辉三角。 杨辉三角中的每个值占六个字符的宽度,左对齐 如果输入超范围,则输出提示信息:input error! 并结束程序的运行。
时间: 2024-10-06 19:05:27 浏览: 43
利用二维数组打印杨辉三角形.docx
在C语言中,你可以使用嵌套循环来生成并打印杨辉三角。杨辉三角是一个由数字构成的金字塔形图案,每一行的数字都是通过前一行计算得出的。对于给定的行数n,我们可以按照以下步骤操作:
1. 首先,声明一个二维数组`tri`来存储杨辉三角的数字,大小应该足够存放n行。
2. 使用两层for循环:外层循环控制行数,从0到n-1;内层循环控制每行的元素,从0到当前行数。
3. 根据杨辉三角的规律,第i行第j个位置的值等于上一行的(i-1)个位置和(i-2)个位置的值之和,条件是0 <= j <= i。
4. 将计算出的值存储在数组`tri[i][j]`中,并注意格式化输出,由于每个数值需要六个字符,所以使用`setw(6)`或者其他字符串格式化函数保证输出宽度过滤。
5. 当输入超过20时,检查边界条件,如果满足则输出提示"input error!",并通过`exit()`或`return`退出程序。
下面是一个简单的C程序示例,展示了如何实现这个功能:
```c
#include <stdio.h>
#include <string.h>
#define MAX_SIZE 20
void printTriangle(int n) {
int tri[MAX_SIZE][MAX_SIZE];
memset(tri, 0, sizeof(tri));
for (int i = 0; i < n; i++) {
// 对于每一行,打印空格填充到足够的长度
for (int j = 0; j < i + 1; j++) {
if (j > 0)
printf("%*d", 6 - j * 2, tri[i - 1][j - 1]); // 左对齐
else
printf(" "); // 第一行的开始和结束都有两个空格
}
printf("\n");
// 计算并存储杨辉三角的值
for (int j = 0; j <= i; j++) {
if (j == 0 || j == i)
tri[i][j] = 1;
else
tri[i][j] = tri[i - 1] + tri[i - 1][j];
}
}
// 检查输入是否超过范围
if (n > MAX_SIZE) {
printf("input error!\n");
return;
}
}
int main() {
int input;
printf("请输入一个不大于20的正整数:");
scanf("%d", &input);
printTriangle(input);
return 0;
}
```
阅读全文