- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图掌握递归的概念,但我无法理解它。有人可以向我解释一下为什么它会这样工作吗?
当我看到这段代码时,我希望唯一打印的内容是 1,因为那是它最终停止调用自身的时候,这就是它在最后一次调用时返回的内容。
def Fib(n):
if n == 1 or n == 2:
return 1
return Fib(n-1) + Fib(n-2)
print Fib(10)
我也尝试这样做,并期望它打印 1,但只得到 None
def foo(n):
if n == 1:
return n
else:
foo(n-1)
print foo(10)
编辑:我很感谢所提供的帮助。我仍然没有看到我的大脑需要的“啊哈”连接!这更可能是由于我的经验的限制,而不是社区解释我的问题的能力。希望所提供的信息能够在我将来回过头来讨论这个问题以及其他问题时对我有所帮助。谢谢你!我会放弃投票,但没有这样做所需的声誉,抱歉!
最佳答案
代码不会打印 1,因为函数返回 1 的唯一方法是当参数 n
时是 1 或 2。所以当你说 print Fib(10)
,结果不会是 1。
相反,控件会转到if
之后的下一行。语句 ( return Fib(n-1) + Fib(n-2)
),它调用 Fib
再次,这次是 9 和 8。这两个函数调用的结果将相加并返回。
现在Fib
使用参数 n
运行设置为 9。由于 9 不等于 1 或 2,因此 Fib
的最后一行同样如此。函数将运行,并且 Fib
将再次调用值 8 和 7。
这种情况持续下去,直到 Fib
被调用 n=1
或n=2
,在这种情况下Fib
将返回 1。它向调用者返回 1,这是 Fib
的实例。使用 n=3
调用时的函数。因此,当您调用 Fib
时会发生以下情况:与 n=3
:
3 不是 1 或 2,因此控制再次转到 Fib
的最后一行, return Fib(n-1) + Fib(n-2)
。这次,这条线路调用 Fib
上n-1
,即 2,并且 n-2
,即 1。这两个函数调用的计算结果均为 1,因此这里的函数向其调用者返回 1+1。
然后,它的调用者将加法的值返回给其调用者,调用者又将其加法的值返回给其调用者,直到调用者是 print
行,仅打印结果。
关于python - 尝试掌握递归函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28106055/
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
我正在尝试理解 promise ,在本例中是在一个循环中。 我的场景基于将文件上传到 Google 云端硬盘。我的理解是,每个文件都应该上传,然后一旦 promise 得到解决,就上传下一个文件,依此
JDK 1.6 包括通过 JAX-WS API 使用 FastInfoset Web 服务的功能。这些的实现隐藏在 com.sun.xml.internal 的深处,包名旨在让任何明智的 Java 开
我正在学习 React 并思考组件的结构。以下内容让我有些困惑。 我们被告知应该有单一的真相来源。 所有者组件应将 props/状态传递给它的责任(有些人称为“ownee”)组件。 所以,如果我自己的
我刚刚开始使用 Google Guice 作为依赖项注入(inject)框架,并试图将其改造为我最近编写的中小型项目。我了解 Guice 工作原理的基础知识,但对一些方法细节有点模糊。例如: 1) 模
上周我们在上周左右的修补和测试后将 Omniture 的分析代码发布到大量网站上。 在我们几乎所有的网站模板上,它都运行良好。在一些零星的、不可预测的情况下,严重的浏览器崩溃体验可能会让一些用户望而却
我刚刚获得了一个 API,它似乎比我习惯的更上一层楼,因为一切似乎都是使用接口(interface)实现的,我正在努力理解它们。 public partial class Form1 : Form,
我的程序似乎很合我意。但是,当我编译它时,我收到了这条消息: Note: Program.java uses unchecked or unsafe operations. Note: Recompi
最近开始用story board、Xcode等学习Swift。我很难理解 ViewController 代码的原理,因为它似乎遗漏了很多基本要素——大概是为了尝试让事情变得更简单——但它不适合来自其他
我刚收到一些有关使用 wpf、c# 的 MVVM 的设计/实现问题。我只是想掌握 MVVM,如果有人能证实我的想法,我正在徘徊,在我的应用程序中,我需要一名员工、一个部门和一家公司。所以换句话说,我有
我在 gird View 中有一个 gridview 和 2 个链接按钮,编辑和删除,单击编辑按钮 s 时,该行的详细信息应显示在“detailsview”中。我的详细信息 View 在更新面板。 最
function def() { console.log(this.x) } var f = def.bind({ x:777 }) f() // prints 777 bind 创建了一个函
我尝试将谷歌地图(外部加载的脚本)添加到 meteor 应用程序,但没有成功,我注意到有两种问题: 如果我做简单的事情并将主要的 API 脚本添加到我的 ,然后它被呈现为last。 发生这种情况时,
如果我理解正确,Node JS 是非阻塞的......所以它不是等待来自数据库或其他进程的响应,而是转移到其他东西并稍后再检查。 它也是单线程的。 这是否意味着给定的 Node JS 进程可以充分有效
几周前,我开始了 Iphone 应用程序开发的研究,在不同设置中进行了大量的 hello world 应用程序之后,我现在已经准备好开发我的第一个基于 Cocoa 中使用的 MVC 设计模式的应用程序
这个问题和我之前的问题很相似。 大约 4 年前,我在 Visual Studio 2005 中使用过 ASP .Net。恢复最新版本需要多长时间? 最佳答案 这取决于您“使用”它的程度。有经验的开发人
如何让这个程序让用户一次输入 5 位数字,而不是每次都询问单独的数字?我知道我必须使用 string.split() 但我将在哪里放置代码并执行代码。 Heading from random impo
因此,根据我的理解,在 3nf 数据库中,主键值可用于确定表中的每个其他属性。 这是否意味着外键将专门用于创建复合实体?外键如何适合 3nf 数据库? 有哪些“迹象”表明我的数据库已标准化?数据库中的
如何解决以下 f(n)=n!据我所知不适用于主定理的任何情况。T(n) = 16T(n/4) + n! 最佳答案 David Eisenstat 部分正确。情况 3 确实适用,但 T(n) = the
在过去的 2.5 年里,我一直在研究 SAP 技术。由于技术概念太多,我无法找到一个可以了解与它相关的所有内容的单一来源。我没有掌握掌握所有技术概念的信心。 如果您遇到过这样的经历以及如何克服它,请帮
我是一名优秀的程序员,十分优秀!