在屏幕上打印杨辉三角。
1
1 1
1 2 1
1 3 3 1
……
首先分析问题,杨辉三角中的数是自己上面的数和上面左边的数相加得到,我们要想在赋值其中一个数的时候就需要调用它上面以及上面的左边的数,因此需要创建一个二维数组,那么这个二维数组需要创建多大的呢?通过观察我们可以得知杨辉三角的行数和列数是一样多的。因为二维数组的创建需要用到常量,为了方便表示,我们可以用 #define 定义一个常量方便后期处理。
#define row 10
#include <stdio.h>
int main()
{
int board[row][row]={0};
return 0;
}
创建完数组之后我们就要分析数组内容进行赋值了,因为我们赋值的规律是取上面的数和上面左边的数加和进行赋值,首先第一行的数没有更上一行的数,且只有一个1,我们可以单独处理,最左边一行的数都是1,且不存在上面左边的数,我们可以在每一行赋值前对其处理。用代码写出来就是
#define row 10
#include <stdio.h>
int main()
{
int board[row][row] = { 0 };
int i = 0;
int j = 0;
board[0][0] = 1;
for (i = 1; i < row; i++)
{
board[i][0] = 1;
for (j = 1; j <= i; j++)
{
board[i][j] = board[i - 1][j] + board[i - 1][j - 1];
}
}
return 0;
}
这样处理之后就可以遍历数组打印出来结果,完美符合预期。
#define row 10
#include <stdio.h>
int main()
{
int board[row][row] = { 0 };
int i = 0;
int j = 0;
board[0][0] = 1;
for (i = 1; i < row; i++)
{
board[i][0] = 1;
for (j = 1; j <= i; j++)
{
board[i][j] = board[i - 1][j] + board[i - 1][j - 1];
}
}
for (i = 0; i < row; i++)
{
for (j = 0; j <= i; j++)
{
printf("%d ", board[i][j]);
}
printf("\n");
}
return 0;
}
如果要修改打印的行数就直接修改 row 的值即可。