求解下面结果,要求详细解答,答案我知道!

#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;
}

先占个位置,给我好评哦!!!

结果: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)); }
}
温馨提示:答案为网友推荐,仅供参考
第1个回答  2013-12-11
画个流程图自己慢慢算,幸亏你输入的不是10,10