输入格式:
输入在一行中给出N(1≤N≤10)。
输出格式:
以正三角形的格式输出前N行杨辉三角。每个数字占固定4位。
#include<stdio.h>
int main()
{
int n;
scanf("%d",&n);
int a[10][10];
for(int i=0;i<n;i++)
{
a[i][0]=1;
a[i][i]=1;
}
for(int i=2;i<n;i++) //通过画图可知 i=0以及i=1,前两行的值已经定义好了
{
for(int j=1;j<i;j++) //只要中间的项,所以 max(j)=i-1
{
a[i][j]=a[i-1][j]+a[i-1][j-1]; //递归
}
}
for(int i=0;i<n;i++)
{
for(int k=n-1-i;k>0;k--) //在4d情况下,每个小于10的数字前面自带3个空格
{ //在输入6时,我们测试到,第一行有5个多余的空格
printf(" "); //自然而然联想到每次要打印n-1-i个空格
}
for(int j=0;j<=i;j++)
{
printf("%4d",a[i][j]); //按照题目要求,4d形式
}
printf("\n");
}
return 0;
}