递归算法转为非递归

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;
}
大神们把我转一下吧
展开
 我来答
yang_bigarm
2012-06-26 · TA获得超过3949个赞
知道大有可为答主
回答量:1664
采纳率:100%
帮助的人:623万
展开全部
你自己维护一个存储空间就行了,我下面这个只是一个大体的思路,具体的细节还靠你自己去完善。
#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;
385338420
2012-06-26 · 超过25用户采纳过TA的回答
知道答主
回答量:94
采纳率:0%
帮助的人:91.6万
展开全部
int fun(int m,int n)
{
int i,j,c;
for(;m!=1;m--){}
for(;n!=1;n--){}
c = a+b;
return c;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式