- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
有问题的问题可以在 http://projecteuler.net/problem=14 找到
我正在尝试我认为新颖的解决方案。至少不是蛮力。我的解决方案基于两个假设:
1) 迭代序列的次数越少,得到答案的速度就越快。 2) 序列必然比其每个元素的序列长
所以我实现了一个包含序列中可能出现的所有可能数字的数组。开始序列的最大数字是 999999(因为该问题只要求您测试小于 1,000,000 的数字);因此,任何序列中的最大可能数字是 3 * 999999 + 1 = 2999998 (这是偶数,因此将除以 2 以获得序列中的下一个数字)。所以数组只需要这个大小。 (在我的代码中,数组实际上是 2999999 个元素,因为我包含了 0,以便每个数字与其数组索引相匹配。但是,这不是必需的,它是为了理解)。
因此,一旦一个数字进入序列,它在数组中的值就会变为 0。如果后续序列达到该值,它们将知道不再继续进行,因为假设它们会更长。
但是,当我运行代码时,在引入“wh:”的行中出现以下错误:
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 3188644
出于某种原因,它试图访问上述值的索引,但该索引不应该访问,因为它超过了可能的最大值 29999999。任何人都可以理解为什么会发生这种情况吗?
请注意,我不知道我的假设是否正确。我是一名业余程序员,而不是数学家。我正在尝试。希望一旦索引正确,我就能知道它是否有效。
代码如下:
private static final int MAX_START = 999999;
private static final int MAX_POSSIBLE = 3 * MAX_START + 1;
public long calculate()
{
int[] numbers = new int[MAX_POSSIBLE + 1];
for(int index = 0; index <= MAX_POSSIBLE; index++)
{
numbers[index] = index;
}
int longestChainStart = 0;
for(int index = 1; index <= numbers.length; index++)
{
int currentValue = index;
if(numbers[currentValue] != 0)
{
longestChainStart = currentValue;
while(numbers[currentValue] != 0 && currentValue != 1)
{
numbers[currentValue] = 0;
if(currentValue % 2 == 0)
{
currentValue /= 2;
}
else
{
currentValue = 3 * currentValue + 1;
}
}
}
}
return longestChainStart;
}
最佳答案
鉴于您无法(轻松)限制序列的可能最大数量,您可能需要尝试不同的方法。我可能会建议一些基于内存的东西。
假设您有一个大小为 1,000,000 的数组。每个条目 i
将表示从 i
到 1 的序列长度。请记住,您不需要序列本身,而只需要序列的长度。您可以从 1 开始填写表格——长度为 0。从 2 开始,长度为 1,依此类推。现在,假设我们正在查看条目n
,它是偶数。您可以查看条目 n/2
处的序列长度,然后将 n
处的值加 1。如果您还没有计算n/2
,只需进行正常计算,直到得到计算出的值。如果 n
为奇数,则类似的过程成立。
这应该会显着缩短算法的运行时间,并防止任何越界错误的问题。
关于java - 欧拉项目 14 : Issue with array indexing in a novel solution,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9563831/
我不知道我做了什么来破坏我的 QtCreator,但是“突然”我所有的编译器问题(警告/错误)不再显示在问题面板中,而是只显示在“编译输出”面板中(我在那里不能使用它们通过单击跳转到错误代码)。 在“
我正在制作游戏作为自学。 我的目标是在鼠标指针后面有一条轨迹。(这有效)但是,当我在 chrome 上打开并运行它时。在达到一定的高度和宽度后,轨迹保留在 Canvas 上而不是被擦掉。谁能帮我解决这
我希望通过在我的HTML文件中适当地格式化我的网站上的文本来增强它的外观。具体地说,我希望确保我的HTML文件中的代码在网站上显示得很好。此外,我正在寻求帮助实现我的网站导航栏。,我希望和其他内容显示
我希望通过在我的HTML文件中适当地格式化我的网站上的文本来增强它的外观。具体地说,我希望确保我的HTML文件中的代码在网站上显示得很好。此外,我正在寻求帮助实现我的网站导航栏。,我希望和其他内容显示
我希望通过在我的HTML文件中适当地格式化我的网站上的文本来增强它的外观。具体地说,我希望确保我的HTML文件中的代码在网站上显示得很好。此外,我正在寻求帮助实现我的网站导航栏。,我希望和其他内容显示
我一直在尝试将背景图像添加到 html 文档中元素的边框: 你可以在这里看到:HTML: Something CSS: a { border-width:10px; border-co
我即将开始一个连接两个程序的项目,一个用c#,一个用c++。我已经有一个可以工作的 c# 程序,它能够与自身的其他版本对话。在开始使用c++版本之前,我想到了一些问题: 1) 我正在使用 protob
我正在尝试线程优先级的影响,当 run 方法中的 println 保留在注释中时,两个线程同时结束,我不理解这种行为,你能解释一下吗?谢谢。 主类 public class Main { public
jQuery 1.4: $('#menu li:last:not(.ignore)').addClass('last'); HTML: item 1 ite
当我创建或查看问题时,我想从Mantis问题跟踪系统中删除选择配置文件及其所有随附字段,因为这些问题与我要创建的任何问题都不相关。 其中包括配置文件部分随附的“平台”,“操作系统”和“操作系统版本”字
我不在Master分支上工作。我正在开发另一种newFeature,该功能也发布在github上。 我知道在处理Master分支时如何解决问题:Closes #XXX。 但是,这仅在我在Master分
我需要在一些UICollectionViewCell中画一个圆圈。具有不同颜色边框和背景颜色的圆圈。我的代码。 UICollectionViewController - (UICollectionVi
我们将Trac用于我正在从事的开源项目。我想将所有公开票导出到Github的Issues。我已经找到了一些可能的小型脚本,但是我想知道是否有人这样做并提出了建议。 理想情况下,它将trac的描述语法转
我对 iOS 编程还比较陌生,但在其他语言(主要是 C# 和 Java)方面拥有丰富的编程经验。 我正在尝试为 iPad 设备的某些产品制作一个类似图片库的东西,其中包含指定的类别。用户界面非常简单,
我已经在中间人中激活了 I18n,如下所示: activate :i18n, mount_at_root: :de 现在我想自动从 / 重定向到 /de。这可能吗? 另外,我想知道为什么中间人使用 p
我已经成功编写了一个程序,可以从 Excel 文件中读取数据并将它们存储在 mysql 的表中。我的程序读取每个文件的第一行,创建表的字段,并将其余数据存储为每列中的值。正是因为这种情况以编程方式发生
这是我的代码。 function m1() { return new Promise(function(resolve, reject) { var files = $('#aws-upl
谁能告诉我这是怎么回事? #include #include #include #include #include class writeManager { std::vector
compile 'com.github.RogaLabs:social-login:1.2.1' compile 'com.github.mukeshsolanki:social-login-help
我有一个巨大的 csv 文件,其中包含 149 列 和 25K+ 行,可以在 MySQL 中上传该文件> 我正在使用MySQL LOAD DATA 查询 表我的查询是: LOAD DATA local
我是一名优秀的程序员,十分优秀!