递归算法转为非递归
intfun(intm,intn){inta,b,c;if(n==1){c=m;}elseif(m==1){c=n;}else{a=fun(m,n-1);b=fun(m-...
int fun(int m,int n)
{
int a,b,c;
if(n==1)
{
c = m;
}
else if(m==1)
{
c = n;
}
else
{
a = fun(m,n-1);
b = fun(m-1,n);
c = a+b;
}
return c;
}
大神们把我转一下吧 展开
{
int a,b,c;
if(n==1)
{
c = m;
}
else if(m==1)
{
c = n;
}
else
{
a = fun(m,n-1);
b = fun(m-1,n);
c = a+b;
}
return c;
}
大神们把我转一下吧 展开
2个回答
展开全部
你自己维护一个存储空间就行了,我下面这个只是一个大体的思路,具体的细节还靠你自己去完善。
#define f(x,y) f[x*n+y]
int* f = malloc(m*n*sizeof(int));
for(i=0;i<m;++i)
f(0,i) = i;
for(j=0;j<n;++j)
f(j,0) = j;
for(i=1;i<m;++i)
for(j=1;j<b;++j)
f(i,j) = f(i-1,j)+f(i,j-1);
ret = f(m,n);
free f;
return ret;
#define f(x,y) f[x*n+y]
int* f = malloc(m*n*sizeof(int));
for(i=0;i<m;++i)
f(0,i) = i;
for(j=0;j<n;++j)
f(j,0) = j;
for(i=1;i<m;++i)
for(j=1;j<b;++j)
f(i,j) = f(i-1,j)+f(i,j-1);
ret = f(m,n);
free f;
return ret;
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询