杨辉三角
杨辉三角形对于小白来说先从一半入手
a[i][j]=a[i-1][j-1]+a[i-1][j];
从数学知识上分析,每个数等于它上方两数之和;
利用这一知识打出杨辉三角一半
两个循环,
一个循环嵌套,一个循环输出,
#include<stdio.h>
int main()
{
int i,j;
int a[10][20];
a[0][0]=1;
for(i=1;i<=9;i++)
{
a[i][0]=1;
a[i][i]=1;
for(j=1;j<i;j++)
{
a[i][j]=a[i-1][j-1]+a[i-1][j];//为每一项赋值.
}
}
for(i=0;i<=9;i++) //循环输出
{
for(j=0;j<=i;j++)
printf("%d ",a[i][j]);
printf("\n");
}
return 0;
}
当然杨辉三角
每行数字左右对称,由1开始逐渐变大。
第n行的数字有n项。
前n行共[(1+n)n]/2 个数
第n行的第m个数和第n-m+1个数相等
注意空格的打法
因此·打出完整的十行如下:
#include<stdio.h>
int main()
{
int i,j,t;
int a[10][20];
a[0][0]=1;
for(i=1;i<=9;i++)
{
a[i][0]=1;
a[i][i]=1;
for(j=1;j<i;j++)
a[i][j]=a[i-1][j-1]+a[i-1][j];
}
for(i=0;i<=9;i++)
{
**for(j=1;j<=20-2*i;j++)
printf(" ");**
for(j=0;j<=i;j++)
printf(" %d ",a[i][j]);
printf("\n");
}
return 0;
}
谢谢观看,希望给你带来帮助。