重点:自三行起,每一个数都它肩上两数之和
解题思路:
1.建立二维数组,存储行和列相关的数据
2.先将数组中所有的数都置为1(不必再特意将首元素和末元素置为1)
3.找出各个数与上一行之间的联系
4.设置相关参数使数组居中显示
5.输出杨辉三角
具体代码如下:
#include <stdio.h>
int main()
{
int i = 0;
int j = 0;
int a[10][10];
for (i = 0; i < 10; i++)
{
for (j = 0; j < 10; j++)
{
a[i][j] = 1;
}
}
for (i = 2; i < 10;i++)//从第三行开始,每个数为其肩上的数之和
{
for (j = 1; j < i; j++)
{
a[i][j] = a[i - 1][j - 1] + a[i - 1][j];
}
}
for (i = 0; i < 10; i++)
{
for (int k = 0; k < 25 - 6 * i / 2; k++)
{
printf(" ");
}
for (j = 0; j <= i; j++)
{
printf("%6d", a[i][j]);
}
printf("\n");
}
return 0;
}
运行截图:
总结:
1.本题关键是找出数字跟上一行的关系:a[i][j]=a[i-1][j-1]+a[i-1][j];
2.居中显示就是在各行前面输入一些空格,只需在左侧输入空格即可(当然了。如果这一步比较难达到,直接输出即可)