我制作了这段代码..我需要充分利用它..我真的需要计算斐波那契数的最佳性能..请帮助..
我已经阅读了一些此类计算的代码,我认为我得到了最好的..
帮我解决这个问题.. plz ..
ps:我真的需要BigInteger ..我将计算大量数字的斐波那契
ps2:我用这个算法计算了一些大数字,我得到了很好的响应时间..但我需要知道它是否可以更好
ps3:要运行此代码,您需要使用此 VM 参数-Xss16384k
(StackSize)
public class Fibonacci {
private static BigInteger[] fibTmp = { BigInteger.valueOf(0), BigInteger.valueOf(1) };
public static BigInteger fibonacci(long v) {
BigInteger fib = BigInteger.valueOf(0);
if (v == 1) {
fib = BigInteger.valueOf(1);
} else if (v == 0) {
fib = BigInteger.valueOf(0);
} else {
BigInteger v1 = fibonacci(v - 1);
BigInteger v2 = fibTmp[(int) (v - 2)];
fib = v1.add(v2);
}
synchronized (fibTmp) {
if (fibTmp.length - 1 < v)
fibTmp = Arrays.copyOf(fibTmp, (int) (v + 10));
fibTmp[(int) v] = fib;
}
return fib;
}
}