请各位大神帮忙讲解一下以下的代码
#include <stdio.h>#include <stdlib.h>
/*杨辉三角*/
int main(int argc, char *argv[])
{
int iInt(int x,int y);
int i,j;
int n=6;
for(i=0;i<=n-1;i++)
{
for(j=1;j<i+2;j++)
{
printf("%4d ",iInt(i,j));
}
printf("\n");
}
return 0;
}
int iInt(int x,int y)
{
int z;
if((y==1)||(y==x+1)) //如果y等于1或y等于x+1
{
return 1;//函数返回值为1
}
else
{
z=iInt(x-1,y-1)+iInt(x-1,y);
return z;
}
}
麻烦各位帮帮忙,讲解一下这个代码,还有递归函数,谢谢啦
你好: 小白c,我也是刚学习c语言,我吧我的见解描述一下;
1、首先这程序有两部分组成,一个 mian函数,一个iInt函数,
2,mian函数中有个双层for循环,外层主要是控制换行(也就是说控制这个杨辉三角有多少行),内层for 循环主要是将iIint函数传回数据进行打印
3、iInt函数中主要是用了递归将前一行的两个相邻数进行相加然后赋值给z,
你可以吧递归看成循环
页:
[1]