- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这是一个纯粹的学术问题:
我最近一直在使用使用尾递归优化的语言。为了练习,我在 R 中编写了两个求和函数的递归实现,其中之一是尾递归。我很快意识到 R 中没有尾递归优化。我可以接受。但是,我也注意到在使用局部辅助函数进行尾递归时允许的深度不同。
代码如下:
## Recursive
sum <- function (i, end, fun){
if (i>=end) 0
else fun(i) + sum(i+1, end, fun)
}
## Tail recursive
sum_tail <- function (i, end, fun){
sum_helper<- function(i, acc){
if (i>=end) acc
else sum_helper(i+1, acc+fun(i))
}
sum_helper(i, 0)
}
## Simple example
harmonic <- function(k){
return(1/(k))
}
print(sum(1, 1200, harmonic)) # <- This works fine, but is close to the limit
# print(sum_tail(1, 1200, harmonic)) <- This will crash
print(sum_tail(1, 996, harmonic)) # <- This is the deepest allowed
我很感兴趣。有人可以解释这种行为或向我指出一份解释如何计算允许的递归深度的文档吗?
最佳答案
我不确定 R 调用堆栈的内部实现,但从这里可以明显看出存在最大堆栈深度。 (许多语言出于各种原因都有这个,主要与内存和检测无限递归有关。)您可以使用 options()
进行设置,默认设置似乎取决于平台——在我的机器上,我可以毫无困难地执行 print(sum_tail(1, 996, harmonic))
。
侧边栏:你真的不应该命名你的天真实现 sum()
因为你最终隐藏了一个内置函数。我知道你只是在这里玩递归,但你通常也应该避免自己实现 sum()
- 它不仅仅是作为一个方便的函数提供的,还因为它的实现并不简单带有 float 的 sum()
的数字正确版本。
在您的原始实现中,对 fun()
的调用在递归调用之前返回——这意味着每次递归调用都会将调用堆栈的深度恰好增加 1。在另一种情况下,您有一个额外的函数调用正在等待评估。有关更多详细信息,您应该查看 R 如何处理闭包以及 R 中的惰性/急切评估是如何处理的。如果我没记错的话,R 使用环境(大致上,R 的范围概念,并且与闭包密切相关)在某些情况下包装参数并延迟它们的评估,从而有效地使用惰性评估。网上有很多关于 R 内部结构的信息,请参阅此处以快速了解 argument evaluation .我不确定我在细节上有多准确,但似乎尾调用的参数本身被放置在调用堆栈中,从而将调用堆栈的深度增加了 1 以上。
第二个侧边栏:我不太记得 R 是如何实现它的,我知道在主体中放置辅助函数是常见的做法,但是在递归调用中放置辅助函数定义可以导致每次递归调用都重新定义辅助函数。这可能会以各种方式与环境和闭包的处理方式相互作用,但我不确定。
函数traceback()
和 trace()
如果您对更多细节感到好奇,可能有助于探索调用行为。
关于R编程: Level of allowed recursion depth differs when calling a local helper function,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26797537/
我正在 Angular js和sails.js(node.js框架)之间的cors问题上挣扎 我尝试修复错误:XMLHttpRequest无法加载http://localhost:1337/en/au
我在我的应用程序中动态创建一个 iframe,结果如下所示: 这样的沙箱配置是否安全(特别是允许将 iframe 内容视为来自同一来源)? 最佳答案 正如 Namey 评论的那样,allow-sam
突然,似乎没有更改我的网络应用程序中的任何内容,我在 Chrome 中打开它时开始收到 CORS 错误。我尝试添加 Access-Control-Allow-Origin: *标题。然后我得到这个错误
我正在使用 Ionic Framework 开发应用程序。 在后端,我为 api 编写了一个 Flask 应用程序,如下所示: @API.route("/saverez",methods=["POST
我正在尝试从 onesignal api 发送 POST 请求 代码 axios({ method: 'post', url: 'https://onesignal.com/api/v1/no
我一直在寻找一些类似的问题来寻找答案,但我找不到。我有一个带有 express 的 node.js 服务器: app.use(function(req, res, next) { res.head
我使用 Google Cloud Functions 创建了一个 API 端点,并试图从 JS 获取函数中调用它。 我遇到了我很确定与 CORS 或输出格式有关的错误,但我不确定发生了什么。其他一些
当我尝试从我的 Angular 6 应用程序访问 Webhdfs 时,我收到如下所示的错误。在我看来,我几乎尝试了所有方法,包括更改 core-site.xml 和 hdfs-site.xml 中的设
我刚刚学习 ajax 和 cors 一些东西,现在我想知道 chrome 插件“allow-control-allow-origin”是如何工作的。 当我尝试执行正常的 ajax 请求时,控制台显示错
我正在努力理解如何允许用户在列表中创建新记录,但只允许创建者更新他们自己的帖子。 例如。以下结构: post { post1: { author: "user1"
我们的网络上有 2 个内部(内联网)Windows 服务器,仅适用于本地网络。在 server1 上安装了 Spark,我们可以在其中查询 Jabber 信息,如下所示: http://server1
所以在 routing.yml 中我定义了以下路由,以便编辑和删除特定设置: 路由.yml: settings.editDefaults: path: settings/{id}/d
我哪里出错了 title $.get("http://api.angel.co/1/tags/1654/startups?callback=aaa", function(data
首先,对您可能犯的语法错误表示歉意。我的英语不是很好。 我是 Spring 新手,我正在尝试创建基本身份验证安全性。 我正在尝试配置一个端点具有公共(public)访问权限,而其他端点则具有用户访问权
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: NULL in MySQL (Performance & Storage) 如果出现以下情况,您是否强烈建议取消选中
我正在尝试将我的一个网站中的内容加载到另一个网站中: $('#include-from-outside').load('http://lujanventas.com/plugins/banne
这里出了什么问题? OPTIONS https://twitter.com/oauth/request_token 401 (Unauthorized) jsOAuth-1.3.4.js:483 XM
allow-control-allow-origin : * header 存在于 API 响应中,但浏览器仍显示错误。网络 403 错误。 这是来自 API 的示例响应 header : Acces
在 Go 中制作 slice 时的 capacity 参数对我来说意义不大。例如, aSlice := make([]int, 2, 2) //a new slice with length and
Gitlab 保护分支中“允许推送”和“允许 merge ”是什么意思 最佳答案 引用 Gitlab Documentation here Using the "Allowed to push" an
我是一名优秀的程序员,十分优秀!