优化Collat​​z序列

时间:2014-01-14 17:26:11

标签: java optimization

我一直在project-euler.net上工作

我最近解决了问题14-请参阅here了解完整说明

这是代码

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。

1 个答案:

答案 0 :(得分:1)

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

例如: 如果您第二次使用数字200,000,您已经知道Collat​​z序列中还有多少步骤。