解题思路:
注意事项:
参考代码:
#include<stdio.h>
int num(int p);//定义函数求整数位数
int main(void)
{
int n;
while(scanf("%d",&n)!=EOF)//输入行数n
{
int a[n][n];//定义对应大小的二维数组
int i,j,k,l;
for(i=0;i<n;i++)
{
a[i][0]=1,a[i][i]=1;
//将每一行的第一个元素和最后一个元素赋值为1
}
for(i=2;i<n;i++)
{
for(j=1;j<=i-1;j++)
{
a[i][j]=a[i-1][j-1]+a[i-1][j];
//每个元素的值为对角两个元素值之和
}
}
for(i=n-1;i>=0;i--)
{
for(j=1;j<=((n-i))*3-1;j++)
{
printf(" ");//输出每行前面的空格
}
for(j=0;j<=i;j++)
{
printf("%d",a[i][j]);
k=num(a[i][j+1]);
for(l=1;l<=(6-k);l++)
{
printf(" ");//根据后面元素位数输出对应数量空格
}
}
printf("\n");
}
printf("\n");
}
return 0;
}
int num(int p) //求位数函数
{
int sum=1;
while(p>=10)
{
p=p/10;
sum++;
}
return sum;
}
0.0分
4 人评分