可能的重复:
结合记忆和尾递归
所以下面是我写的代码,使用累积变量优化的尾调用
let rec counter init count =
if init = 1 then count + 1 else
match init with
| Even value -> (counter (value/2) (1 + count))
| Odd value -> (counter ((3 * value) + 1) (count+1))
let SeqBuilder (initval:int) : int =
counter initval 0
我如何记住这个?当我尝试记忆时遇到的问题是递归调用必须转到记忆对象,所以你必须有一个......递归对象?
还是它更简单,我只是缺乏经验?