求C语言程序
用二维数组的方法输出杨辉三角如
1
1 1
1 2 1
1 3 3 1
…
要求输出10行。
追问:结果我知道哦 就是程序没想到
用二维数组的方法输出杨辉三角如
1
1 1
1 2 1
1 3 3 1
…
要求输出10行。
追问:结果我知道哦 就是程序没想到
答案:#include <stdio.h>
main()
{ int i,j,n=0,a[17][17]={0};
while(n<1 || n>16)
{ printf("请输入杨辉三角形的行数:");
scanf("%d",&n);
}
for(i=0;i<n;i++)
a[i][0]=1; /*第一列全置为一*/
for(i=1;i<n;i++)
for(j=1;j<=i;j++)
a[i][j]=a[i-1][j-1]+a[i-1][j];/*每个数是上面两数之和*/
for(i=0;i<n;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
......呵呵
好久没想了
加油、c语言是很不错的语言
好好学吖、、、
#include <stdio.h>
void main()
{int a[7][7];
int i,j ;
for (i=6;i>=0;i--)
{a[0]=1;
a=1;
}
for (i=2;i<7;i++)
for(j=1;j<i;j++)
{a[j]=a[j]+a[j-1] ;
}
for(i=6;i>=0;i--)
{for(j=6-i;j>=0;j--)
{printf("%d\t",a[6-i][j]) ;
}
printf("\n");
}}
可知杨辉三角满足组合的关系,即通过知道每项的计算公式。则有:
#include<stdio.h>
#include<stdlib.h>
int fn(int n)
{
if(n==0)return 1;
else
return n*fn(n-1);
}
int main()
{
int i,j,n,a,b,c;FILE *f;
f=fopen("yh.txt","w");
scanf("%d",&n);
for(j=0;j<=n;j++)
{
for(i=j;i<n;i++)fprintf(f,"%5s","");
for(i=0;i<=j;i++)
{
a=fn(j);b=fn(i);c=fn(j-i);
fprintf(f,"%8d",a/(b*c));
}
fprintf(f,"\n");
}
fclose(f);
system("yh.txt");//显示结果
return 0;
}运行结果如下: