首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >计算期间堆栈溢出(循环递归?)错误

计算期间堆栈溢出(循环递归?)错误
EN

Stack Overflow用户
提问于 2018-04-24 08:48:45
回答 1查看 654关注 0票数 1

函数seq应该返回从init开始的序列,并且在每次按步骤扩展,直到条件未被验证为止:

代码语言:javascript
复制
let  rec seq init step cond () = 
let r = ref init in
if cond !r 
then  Cons(step !r, seq !r step cond)
else Nil 

我尝试了这些(to_list (seq1seq1(趣味x -> x+1) )(趣味x -> x<10),并且在计算期间有堆栈溢出(循环递归?)。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-04-24 11:30:50

首先,你应该避免在没有充分理由的情况下使用引用。那么,这只是存储当前值的问题,而不是下一个值的问题:

代码语言:javascript
复制
let rec seq current step cond () =
if cond current then 
  Cons(current, seq (step current) step cond)
else
  Nil
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49997241

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档