Fibonacci number is negative(斐波纳契数为负数)
本文介绍了斐波纳契数为负数的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我使用动态编程技术编写了以下代码,但当我对数字220运行Fibonacci时得到一个负数。此程序中是否有错误?
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;
}
}
}
推荐答案
使用BigInteger
而不是int
/Integer
来避免依瓦略指出的精度问题(Java的<[2-1]和Integer
不能表示大于231位的无符号整数,long
/Long
不超过263)。BigIntegersupports arbitrary precision(仅受JVM可用的内存量限制)。
您的代码将如下所示:
private static BigInteger fib(int n, HashMap<Integer, BigInteger> memoized) {
System.out.println(" n = " + n);
if (memoized.containsKey(n)) {
return memoized.get(n);
} else if (n <= 0) {
return BigInteger.ZERO;
} else if (n <= 2) {
return BigInteger.ONE;
} else {
BigInteger sum = fib(n - 1, memoized).add(fib(n - 2, memoized));
System.out.println(" fib(" + n + ") = " + sum;
memoized.put(n, sum);
return sum;
}
}
这篇关于斐波纳契数为负数的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:斐波纳契数为负数
基础教程推荐
猜你喜欢
- 如何强制对超级方法进行多态调用? 2022-01-01
- 在螺旋中写一个字符串 2022-01-01
- 如何在不安装整个 WTP 包的情况下将 Tomcat 8 添加到 Eclipse Kepler 2022-01-01
- 由于对所需库 rt.jar 的限制,对类的访问限制? 2022-01-01
- 如何使用 Stream 在集合中拆分奇数和偶数以及两者的总和 2022-01-01
- Java 中保存最后 N 个元素的大小受限队列 2022-01-01
- Spring Boot Freemarker从2.2.0升级失败 2022-01-01
- 如何使用 Eclipse 检查调试符号状态? 2022-01-01
- 首次使用 Hadoop,MapReduce Job 不运行 Reduce Phase 2022-01-01
- 如何对 HashSet 进行排序? 2022-01-01