
求解下面结果,要求详细解答,答案我知道!
#include<iostream>usingnamespacestd;intack(intm,intn){if(m==0)returnn+1;elseif(n==0)r...
#include<iostream>
using namespace std;
int ack(int m,int n)
{
if(m == 0)
return n + 1;
else if(n == 0)
return ack(m-1,1);
else
return ack(m - 1 , ack(m , n-1));
}
void main()
{
cout<<ack(3,3)<<endl;
} 展开
using namespace std;
int ack(int m,int n)
{
if(m == 0)
return n + 1;
else if(n == 0)
return ack(m-1,1);
else
return ack(m - 1 , ack(m , n-1));
}
void main()
{
cout<<ack(3,3)<<endl;
} 展开
2个回答
展开全部
先占个位置,给我好评哦!!!
结果:61
兄弟,告诉你个很不幸的结果,经过了几千次的运算,这个真心没法给你详细过程的啊!!!
不过我可以给你提供给一个思路,你加入如下打印,就可以看出计算过程:
如下:
static int mFlag = 0;//运算次数
static int ack(int m,int n)
{
if(m == 0){ System.out.println("n+1=="+mFlag++);
return n + 1;
}
else if(n == 0) {System.out.println("ack(m-1,1)=="+mFlag++);
return ack(m-1,1); }
else {System.out.println("ack(m - 1 , ack(m , n-1))=="+mFlag++);
return ack(m - 1 , ack(m , n-1)); }
}
结果:61
兄弟,告诉你个很不幸的结果,经过了几千次的运算,这个真心没法给你详细过程的啊!!!
不过我可以给你提供给一个思路,你加入如下打印,就可以看出计算过程:
如下:
static int mFlag = 0;//运算次数
static int ack(int m,int n)
{
if(m == 0){ System.out.println("n+1=="+mFlag++);
return n + 1;
}
else if(n == 0) {System.out.println("ack(m-1,1)=="+mFlag++);
return ack(m-1,1); }
else {System.out.println("ack(m - 1 , ack(m , n-1))=="+mFlag++);
return ack(m - 1 , ack(m , n-1)); }
}
2013-12-11
展开全部
画个流程图自己慢慢算,幸亏你输入的不是10,10
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询