1

用 Java 编写的标准阿克曼公式:

public static int ack(int x, int y) {

        if (x == 0) {
            return y + 1;
        } else if (y == 0) {
            return ack(x-1, 1); 
        } else {
            // perforce (x > 0) && (y > 0)
            return ack(x-1, ack(x,y-1));
        }
    }

我一直在想 - 有没有更快的版本来实现这个?我在想也许有通过使用累加器或循环。

4

3 回答 3

3

是的,例如通过“作弊”。如果m为 5 或更高,则任何结果都不能用int. 对于m = 4,只能表示n < 2案例。对于m < 4,有基于 的简单封闭公式n

无论如何,其他一切都会溢出,所以让我们假设这些情况甚至没有发生(或者你可能会抛出错误或其他什么)。

未测试:

int Ackerman(int m, int n) {
    switch (m) {
    case 0:
        return n + 1;
    case 1:
        return n + 2;
    case 2:
        return n * 2 + 3;
    case 3:
        return (int)((1L << (n + 3)) - 3);
    case 4:
        return n == 0 ? 13 : 65533;
    }
}
于 2013-12-05T21:45:20.190 回答
2

我可以告诉你一件事......int对于 x 和 y 的很多值是不够的

如果您要重复调用该函数,您可以创建一个int[][]数组来存储各种值,以便您可以在第二次以上查找它们并且只需要计算一次。但至于加速单次执行……不确定。

于 2013-12-05T21:20:26.103 回答
1

这种变化更快:

public static int ack(int x, int y) {
    while (x != 0) {
        y = y == 0 ? 1 : ack(x, y - 1);
        x--;
    }
    return y + 1;
}
于 2013-12-05T21:33:00.353 回答