自学内容网 自学内容网

计算并输出杨辉三角形的前10行

第一种方法,代码如下:

#include <stdio.h>
main()
{
int a[10][10]={0};
int n,i,j;
printf("请输入要打印的行数: ");
scanf("%d",&n);

for(i=0;i<n;i++)
for(j=0;j<=i;j++)
{
if(j==0||j==i)
a[i][j]=1;
else
a[i][j]=a[i-1][j]+a[i-1][j-1];
}
for(i=0;i<n;i++)
{for(j=0;j<=i;j++)
printf("%-5d ",a[i][j]);
     printf("\n");
}
}

第二种方法,代码如下:

#include <stdio.h>
main()
{
int a[10][10],i,j;
for(i=0;i<10;i++)
{
a[i][0]=1;
a[i][i]=1;
}
for(i=2;i<10;i++)
for(j=1;j<i;j++)
a[i][j]=a[i-1][j]+a[i-1][j-1];
for(i=0;i<10;i++)
{
for(j=0;j<=i;j++)
printf("%-5d",a[i][j]);
printf("\n");
}
}

结果如下:

1
1    1
1    2    1
1    3    3    1
1    4    6    4    1
1    5    10   10   5    1
1    6    15   20   15   6    1
1    7    21   35   35   21   7    1
1    8    28   56   70   56   28   8    1
1    9    36   84   126  126  84   36   9    1
请按任意键继续. . .


原文地址:https://blog.csdn.net/m0_61714219/article/details/140587250

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!