什么是范围内最大的Collatz序列的数字?
我必须使用递归编写一个程序,该程序给定n返回最小值m,1≤m≤n,该递归生成了最长的collatz步骤序列,
例如20,必须返回的数字为18,因为18和19两者都产生最多的步骤(20)至1,但是18个较小。 我们得到了几个正确的答案的示例:
*Main> longestSequenceTo 13
9
*Main> longestSequenceTo 30
27
*Main> longestSequenceTo 88
73
*Main> longestSequenceTo 1121
871
我最大的问题是我们不允许使用列表,而我们对Haskell的了解仍然非常基本。 我设法将Collatz的猜想写为一个功能,我想我知道我的主要功能上的递归条件应该是什么:
collatz :: Integer->Integer
collatz 1 = 0
collatz n | even n = 1 + collatz (div n 2)
| otherwise = 1 + collatz (3*n+1)
我认为我的功能应该看起来像:
longestSequence n | collatz n <= collatz (n-1) =
| otherwise =
我的问题是我不知道如何“存储” “实际n,而不是要获得数字达到1的步骤数量
I have to write a program using recursion that, given n, returns the minimum value m, 1 ≤ m ≤ n, that generates the longest sequence of Collatz Steps
For example 20, the number that has to return is 18, because 18 and 19 both generate the most amount of steps (20) to 1, but 18 is smaller.
We got a couple examples of what correct answers look like:
*Main> longestSequenceTo 13
9
*Main> longestSequenceTo 30
27
*Main> longestSequenceTo 88
73
*Main> longestSequenceTo 1121
871
My biggest issue is that we're not allowed to use lists, and our knowledge of Haskell is very basic still.
I've managed to write the collatz conjecture as a function, and I think I know what my condition should be for the recursion on the main function:
collatz :: Integer->Integer
collatz 1 = 0
collatz n | even n = 1 + collatz (div n 2)
| otherwise = 1 + collatz (3*n+1)
i think my function should look something like:
longestSequence n | collatz n <= collatz (n-1) =
| otherwise =
my problem is I dont know how to "store" the actual n, instead of getting the number of steps a number has to take to reach 1
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
在您“认为您的
最长序列n
函数的方式”中,您仅将n
的值与n-1 。最长的序列可能位于其他地方。此外,对于每个N,您都会两次计算Collatz长度。您只需要计算
n
的长度,然后将其与到目前为止找到的最大值进行比较。考虑以下过程,该过程将找到最大序列长度最高为n,而无需使用列表:
您可以跟踪到目前为止找到的最大值,并使用变量
z
。然后,您可以使用x
和z
的修改值进行下一个运行。当x等于n时,将获得结果。但是您真正追求的不是长度,而是先产生该长度的人...您可以提出所需的更改
z
和z'
以跟踪最大长度和产生的数字n?尝试在下面的提示下完成功能:z
将具有(value,x)的元组形式:In the way you "think your
longestSequence n
function should look like", you are only comparing the value atn
with the value atn-1
. The longest sequence could lie somewhere else. Besides, for each n you calculate the collatz length twice. You only need to calculate the length forn
and compare it with the maximum value found so far.Consider the following procedure that will find the maximum sequence length up to n, without using lists:
You keep track of the max value found so far, with the variable
z
. And you feed the next run with modified values ofx
andz
. The result is obtained when x is equal to n.But what you are really after is not the length but who produced that length first... Can you come up with the needed changes to
z
andz'
to keep track of both a maximum length and the number n that produced it? Try to finish the function below Hint:z
will have the form of a tuple of (value,x):首先,我们将您运行的值命名,因此我们可以在思考过程的单独步骤中决定如何处理它们:
因此,现在我们可以看到您正在倒计时;让我们算一下:
但这仅为我们提供了两个值的collatz长度的值;我们需要所有这些;救援递归! -
现在有正确的结构。它为
和
最长序列
k+1
(从技术上讲,它调用go go go)在
GO
)。换句话说,如果您知道
k+1
和n
n 之间的数字(以及长度)该序列),您知道k
的顺序长度,您可以决定k
andn
具有最长的序列(并且也知道的长度为序列),然后返回 。我还写了更多答案关于递归方法背后的思维过程解决问题,查看它们是否有帮助。
First we name the values you operate on, so we can decide what to do with them in a separate step of our thought process:
So now we can see you're counting down; let's count up instead:
but this only gives us the values of Collatz length for two values; we need them all; recursion to the rescue! --
This has the right structure now. It does the
collatz
fork
, andlongestSequence
fork+1
(technically, it callsgo
), so that you can compare these results to create the result forlongestSequence
fork
(technically, this is the result ofgo
).In other words if you know the number between
k+1
andn
with the longest sequence (and the length of that sequence), and you know the length of the sequence fork
, you can decide which number betweenk
andn
has the longest sequence (and also know the length of that sequence), and return that.I also wrote some more answers about the thought process behind the recursion method of problem solving, see if any of them helps.