- 杨辉三角的性质:
1.每个数等于它上方两数之和。
2.每行数字左右对称,由1开始逐渐变大。
3.第n行的数字有n项。
4.前n行共[(1+n)n]/2 个数。
5.第n行的m个数可表示为 C(n-1,m-1),即为从n-1个不同元素中取m-1个元素的组合数。
6.第n行的第m个数和第n-m+1个数相等 ,为组合数性质之一。
7.每个数字等于上一行的左右两个数字之和。可用此性质写出整个杨辉三角。即第n+1行的第i个数等于第n行的第i-1个数和第i个数之和,这也是组合数的性质之一。即
C(n+1,i)=C(n,i)+C(n,i-1)。
8.(a+b)n的展开式中的各项系数依次对应杨辉三角的第(n+1)行中的每一项。
- 分析过程
对于这些性质中我们在编程中主要注意第一条性质:每个数等于它上方两数之和。
以及第2条:每行数字左右对称,由1开始逐渐变大。
由此杨辉三角如图:
如图所示,我们可以先确定第一列和每行最后一个数赋值为1
定义一个二维数组为a[n][n] = { };
for (int i = 0; i < n; i++)
{
a[i][0] = 1;
a[i][i] = 1;
}
第3行的中间2,是由上面的1+1得到的
第4行