方法一:一维数组
//杨辉三角
#include<stdio.h>
int main()
{
//初始化
int ar[10]={1};
int br[10]={1,1};
int n=10;
for(int i=0;i<n;)
{
//br 给 ar的过程
//0 2 4 6 8 10
ar[0]=ar[i]=1;
for(int j=1;j<i;++j)
{
ar[j]=br[j-1]+br[j];
}
for(int k=0;k<i+1;++k)
{
printf("%5d",ar[k]);
}
printf("\n");
++i;
//ar 给 br的过程
br[0]=br[i]=1;
for(int j=1;j<i;++j)
{
br[j]=ar[j-1]+ar[j];
}
for(int k=0;k<i+1;++k)
{
printf("%5d",br[k]);
}
printf("\n");
++i;
}
return 0;
}
方法二:二维数组
#include<stdio.h>
#include<stdlib.h>
int main()
{
int a[10][10]={0};
for(int i=0;i<=9;i++)
{
for(int j=0;j<=i;j++)
{
if(j==0 || i==j)
{
a[i][j]=1;
}
else
{
a[i][j]=a[i-1][j-1]+a[i-1][j];
}
printf("%-5d",a[i][j]);
}
printf("\n");
}
}