我尝试用 Java 编写递归 Ackermann 函数。但我想我在某个地方走错了!任何人都可以看看,检查并指出我纠正代码的正确方向吗?谢谢!
我对代码的问题是,在我写完它之后,我想,如果 n == 0 和 m == 0,没有这个区域怎么办?这会属于 if (m == 0) 还是需要它自己的 if 语句?
我的以下解决方案是否正确?如果我以不同的顺序给它相同的数字,它会给出不同的结果,我不确定这是否是这种情况。
public static int ackermann(int m, int n) {
if (m == 0) {
return n + 1;
} else if ((m > 0) && (n == 0)) {
return ackermann(m-1, n);
} else if ((m > 0) && (n > 0)) {
return ackermann(m-1, ackermann(m,n-1));
} else {
return 0;
}
}
我想了更多,我认为我错得更大。如果你不知道我做了什么,我给了每个 if 语句一个相反的,因为我认为如果 m 和 n 值以不同的方式给出,下面的代码将起作用。显然没有,但有人可以尝试解释我哪里出错了吗?
public static int ackermann(int m, int n) {
if (m == 0) {
return n + 1;
} else if (n == 0) {
return m + 1;
} else if ((m > 0) && (n == 0)) {
return ackermann(m-1, n);
} else if ((n > 0) && (m == 0)) {
return ackermann(n-1, m);
} else if ((m > 0) && (n > 0)) {
return ackermann(m-1, ackermann(m,n-1));
} else if ((n > 0) && (m > 0)) {
return ackermann(n-1, ackermann(n, m-1));
} else {
return 0;
}
}