首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >优化Collatz序列

优化Collatz序列
EN

Stack Overflow用户
提问于 2014-01-14 17:26:10
回答 1查看 413关注 0票数 3

我在euler.net项目中一直在努力工作。

我最近解决了问题14-请参阅这里获得完整的描述

这是代码

代码语言:javascript
复制
public static void findHighestCollatzNumber()
{
    long greatestNumberOfTerms=0;
    long highestTermNumber=0;
    for(int i=1;i<=ONE_MILLION;i++)
    {
        long noOfTerms=getNumberOfCollatzTerms(i);
        if(noOfTerms>greatestNumberOfTerms)
        {
            greatestNumberOfTerms=noOfTerms;
            highestTermNumber=i;
        }
    }
    System.out.println("highest number of term "+greatestNumberOfTerms + " for "+highestTermNumber);
}

public static long getNumberOfCollatzTerms(long n)
{
    long numberOfTerms=1;
    long i=n;
    do
    {
        i=calculateCollatz(i);
        if(i>0)
        {
            numberOfTerms++;
        }   
    }
    while(i!=1 && i>0);
    return numberOfTerms;
}


public static long calculateCollatz(long n)
{
    long collatz=0;
    if(n%2==0)
    {
        collatz=n>>1;
    }
    else
    {
        collatz=(n<<1)+1+n;
    }
    return collatz;
}

它给出了正确的输出,但计算需要大量时间。

我也尝试过使用按位运算来实现更快的输出,但是仍然需要时间,我如何减少它呢?

我已经研究过其他解决方案,但大多数都是针对ghc或C++或Python的。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-01-14 17:52:31

您需要使用HashMap来避免多次重新计算相同的数字。检查HashMap是否已经包含了数字是一个快速的过程,可以为您节省许多步骤。

例如:如果你第二次进入数字200,000,你已经知道在Collatz序列中还有多少步骤。

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

https://stackoverflow.com/questions/21119920

复制
相关文章

相似问题

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