java - 优化 Collat​​z 序列

标签 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。

最佳答案

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

例如: 如果您第二次达到 200,000 这个数字,您就已经知道 Collat​​z 序列中还有多少步了。

关于java - 优化 Collat​​z 序列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21119920/

相关文章:

java - 如何通过单击抽屉导航上的 ImageView 来获取用户个人资料图片,从图库中选择图像

java - Java中JOptionPane的ConfirmDialog

mysql - 使用 Exists 时,我应该对多个子查询使用 OR 还是对所有子查询使用 UNION?

mysql - 以更好的方式编写此 SQL 查询的好方法是什么?

angularjs - 使用 AngularJS 等单页框架时如何使用 NodeJS 解决社交分享和搜索引擎问题

css - 优化网站上加载的资源

java - 创建 mongodb 健康检查(在 dropwizard 中)

java - Calendar#getFirstDayOfWeek() 返回错误值

java - 为什么哨兵搜索比线性搜索慢?

java - 使用 UnetSocket 在 unetstack 中创建客户端和服务器节点之间的通信