- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
虽然我在理解递归方面没有任何问题,但我似乎无法理解汉诺塔问题的递归解决方案。这是来自 Wikipedia 的代码:
procedure Hanoi(n: integer; source, dest, by: char);
Begin
if (n=1) then
writeln('Move the plate from ', source, ' to ', dest)
else begin
Hanoi(n-1, source, by, dest);
writeln('Move the plate from ', source, ' to ', dest);
Hanoi(n-1, by, dest, source);
end;
End;
我了解基本情况以及将问题分解为更小部分的概念,直到您能够移动单个磁盘。但是,我无法弄清楚非基本情况下的两个递归调用如何一起工作。也许有人可以帮助我?谢谢。
最佳答案
实际上,section from where you took that code还提供了解释:
To move n discs from peg A to peg C:
- move n−1 discs from A to B. This leaves disc #n alone on peg A
- move disc #n from A to C
- move n−1 discs from B to C so they sit on disc #n
很明显,您首先必须删除 n - 1 张光盘才能访问第 n 光盘。而且你必须先将它们移动到另一个钉子上,而不是你希望整个塔出现的位置。
除了光盘数量之外,您帖子中的代码还包含三个参数:源钉、目的地钉和临时钉其间可以存储哪些光盘(每个大小为 n - 1 的光盘都适合)。
递归实际上发生了两次,一次在 writeln
之前,一次在之后。 writeln 之前的一个会将 n - 1 个光盘移动到临时 Hook 上,使用目标 Hook 作为临时存储(递归调用中的参数顺序不同)。之后,剩余的圆盘将被移动到目标桩,然后第二次递归通过将 n - 1 塔从临时桩移动到目标桩来强制移动整个塔。光盘n.
关于recursion - 汉诺塔 : Recursive Algorithm,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1223305/
这是我正在做的作业。我创建了 2 个类来玩汉诺塔。第一个基本上是运行实际游戏类的运行者。 import java.util.Scanner; class TowersRunner { publ
这是我为汉诺塔问题编写的 Python 代码,其中塔必须从左桩转移到中间桩,使用右桩作为备用: def hanoi(n, origin = "1", destination = "2", spare
我正在使用 jQuery 标签!库创建用户“技能”输入表单。我认为这将是一个非常快速和简单的设置,就像大多数 jQuery 库一样,但是我在这个方面遇到了很多麻烦。我尝试按照下面示例中的源代码进行操作
我如何(如果可能)使用 C++11 可变参数编程来定义一系列 vector是在一个函数体内,(或者换句话说,一系列 N 维数组,递减 N 直到 0),就像下面的变量一样? vector>> v; ve
我编写了一个 Ansible playbook,它需要运行它的作业编号作为其参数之一,以便我将对该作业的引用添加到我维护的数据库中。如何获取 Tower 模板以将其传递给剧本? 这是我当前的解决方案,
默认情况下,android 会存储最后 200 个 wifi 连接和 50 个单元位置详细信息。 我使用 WifiManager 中的 getConfiguredNetworks() 获得了 wifi
如何(如果可能)使用 c++11 可变参数编程来定义一系列 vector 's 在函数体中,(或者换句话说,N 维数组的序列,N 's 递减直到 0),就像下面的变量? vector>> v; vec
我们正在 Tensorflow 上运行多 GPU 作业,并评估从基于队列的模型(使用 string_input_producer 接口(interface))到新的 Tensorflow 数据集 AP
我有一个由另一个进程启动的 Ansible 作业。现在我需要检查 Ansible Tower 中当前正在运行的作业的状态。 我可以使用 REST API 使用 /jobs/{id} 跟踪状态是否正在运
我正在使用一个非常棒的插件,名为 jQuery Tagit在我当前项目的开发中。 一切都进行得很顺利(令人怀疑),直到我尝试添加自己的一小部分 jQuery。我的目标是让最终用户可以选择使用按钮添加标
我是一名优秀的程序员,十分优秀!