1、先使得输入的数据在对角线下方
可以看成它是由一个10行10列的的正方形,只取对角线以下的数据。我们输入数据的时候,也只需要对角线一下的数据,显示杨辉三角。
for(i=0;i<10;i++) //i表示行
for(j=0;j<=i;j++) //j表示列
这样循环输入的数据都是在对角线下方。
2、第一列始终为1
可以用
a[i][0]=1; //使得第一列始终为1
3、输入数据之间的规律
第一列的数据在上面已经出来了,下面就是怎么使得对角线下面的其他数据也符合杨辉三角的特性呢?
我们可以发现每一行从第二个数据开始都与前一行的前两列数据有关。
它的值等于它的前两行的前两列数据之和,即
a[i][j]=a[i-1][j-1]+a[i-1][j]
对角线上的元素在它上方的数据为0时,也满足该关系。
综上分析过程,我们就可以写出它的输入代码如下;
int a[10][10]={0}; //初始化数组内的元素全为0
for(i=0;i<10;i++)
{
a[i][0]=1;
for(j=1;j<i+1;j++)
{
a[i][j]=a[i-1][j-1]+a[i-1][j];
}
}
前10行杨辉三角完整代码如下
#include<stdio.h>
int main()
{
int i,j;
int a[10][10]={0}; //怎么定义这个数组?
for(i=0;i<10;i++)
{
a[i][0]=1;
for(j=1;j<i+1;j++)
{
a[i][j]=a[i-1][j-1]+a[i-1][j];
}
}
for(i=0;i<10;i++)
{
for(j=0;j<i+1;j++)
{
printf("%d\t",a[i][j]);
}
printf("\n");
}
return 0;
}