首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >回忆Fibonacci不运行与常规Fibonacci解决方案

回忆Fibonacci不运行与常规Fibonacci解决方案
EN

Stack Overflow用户
提问于 2018-12-03 23:37:02
回答 1查看 56关注 0票数 0

所以我正在学习动态编程,我试着测试我的回忆录解决方案和普通的fibonacci解决方案。当我输入一个相当大的数字,比如43,我的回忆录解决方案要花费很长时间才能运行,而正常的解决方案,运行时间是5-6秒。这是否意味着我的回忆录解决方案实际上没有存储已经看到的结果?

以下是我的传统解决方案:

代码语言:javascript
复制
public static int fibonacci(int i) 
{
    if(i == 0) 
    {
        return 0;
    }
    if(i <= 2) 
    {
        return 1;
    }
    return fibonacci(i - 1) + fibonacci(i - 2);
}

记忆解决方案:

代码语言:javascript
复制
public static int fibonacci(int n) 
{
    Map<Integer, Integer> memo = new HashMap<>();
    if(n == 0) 
    {
        return 0;
    }
    if(n <= 2)
    {
        return 1;
    }
    if(memo.containsKey(n))
    {
        return memo.get(n);
    }
    int result = fibonacci(n - 1) + fibonacci(n - 2);
    memo.put(n, result); 
    
    return result;
}

主要方法:

代码语言:javascript
复制
public static void main(String[] args) {
    Scanner scanner = new Scanner(System.in);
    int n = scanner.nextInt();
    scanner.close();
    System.out.println(fibonacci(n));
}

如能对此作出任何解释,将不胜感激:)

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-12-03 23:42:43

多亏了@shmosel,我才能发现,在我的“回忆录”解决方案中,每次调用新地图时,这个方法都会非常慢!我绕过了这一点,将映射作为实例变量添加,如下所示:

代码语言:javascript
复制
private static Map<Integer, Integer> memo = new HashMap<>();

public static int fibonacci(int n) 
{
    if(n == 0) 
    {
        return 0;
    }
    if(n <= 2)
    {
        return 1;
    }
    if(memo.containsKey(n))
    {
        return memo.get(n);
    }
    int result = fibonacci(n - 1) + fibonacci(n - 2);
    memo.put(n, result); 

    return result;
}

这大大提高了性能。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53603575

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档