【发布时间】:2014-07-21 14:06:22
【问题描述】:
我使用动态编程技术编写了以下代码,但是当我对数字 220 运行斐波那契时得到一个负数。这个程序有错误吗?
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
public class Fibonaci {
public static void main(String[] args) {
System.out.println(" number ");
long startTime = System.currentTimeMillis();
HashMap<Integer, Integer> memoized = new HashMap<Integer, Integer>();
int fib = fibonanci(220, memoized);
System.out.println(" Total Time "
+ (System.currentTimeMillis() - startTime));
}
private static int fibonanci(int n, HashMap<Integer, Integer> memoized) {
System.out.println(" n " + n);
if (memoized.containsKey(n)) {
return memoized.get(n);
}
if (n <= 0) {
return 0;
}
if (n <= 2) {
return 1;
} else {
int febonani = fibonanci(n - 1, memoized)
+ fibonanci(n - 2, memoized);
System.out.println(" febonani " + febonani);
if (!memoized.containsKey(n)) {
memoized.put(n, febonani);
}
return febonani;
}
}
}
【问题讨论】:
-
我建议在此处使用
List(例如ArrayList),而不是HashMap的非常大的开销。 -
if (!memoized.containsKey(n))行似乎没有必要,因为如果 n 在函数开始时不在记忆数据结构中,那么它就不会在其中(除非你有多个线程改变结构)。
标签: java dynamic-programming fibonacci memoization