[问题] 新手提问 有关河内塔的递回理解

楼主: ciakkk040156 (险峻的海峡)   2016-10-14 20:49:04
各位前辈好,这是我在ppt第一次发文,因在河内塔题目有所误解,
只好硬著头皮请教各位前辈...
可悲的是我已经google过一些文章后答案竟然也看不懂,
恳请大大们赐教:
import java.io.*;
public class Hanoi {
public static void main(String args[]) throws IOException {
int n;
BufferedReader buf;
buf = new BufferedReader(new InputStreamReader(System.in));
System.out.print("请输入盘数:");
n = Integer.parseInt(buf.readLine());
Hanoi hanoi = new Hanoi();
hanoi.move(n, 'A', 'B', 'C');
}
public void move(int n, char a, char b, char c) {
if(n == 1)
System.out.println("盘" + n + "由" + a + "移至" + c);
else {
move(n - 1, a, c, b);
System.out.println("盘" + n + "由" + a + "移至" + c);
move(n - 1, b, a, c);
}
}
当输入n=2时会跑出:
(1)盘 1 由 A 移至 B
(2)盘 2 由 A 移至 C
(3)盘 1 由 B 移至 C
对于以上程式码我的理解是
当n=2 即从else开始 move(2-1,a,c,b) 又等于 (1,a,c,b) 所以此时会印出盘1由A移至B
我的疑问在(2)不理解,为什么此时不是跑回n=1 if条件句且应该要印出盘1由A移至C呢?
这是我在网络上找到的解答:
n=2
Step1: move(n - 1, a, c, b); 等于是 move(1, a, c(相当于b), b(相当于c));
System.out.println("盘 " + n + " 由 " + a + " 移至 " + c); 等于 System.out.println("盘 1 由 a 移至 b);
Step2: System.out.println("盘 " + n + "由 " + a + " 移至 " + c) 等于 System.out.println("盘 2 由 a 移至 c)
Step3: move(n - 1, b, a, c); 等于是 move(1, b(相当于a), a(相当于b), c);
System.out.println("盘 " + n + " 由 " + a + " 移至 " + c); 等于 System.out.println("盘 1 由 b 移至 c);
1.究竟Step2是怎么生成的?(我有尝试使用eclipse中的debug但失败了可能是方法有错)
谢谢大家的耐心回应,很不好意思但透过大家的帮忙我已经理解了!
作者: nodoors (门都没有)   2016-10-14 21:32:00
step2是else里第二行@@
作者: pttworld (批踢踢世界)   2016-10-14 21:39:00
debug在move method下行断点,watch到n=2后单步执行。
作者: maxsho (沉默的熊)   2016-10-14 23:36:00
先把if else叙述在做什么先弄清楚当n不是1时,会执行else内的全部叙述 执行move(n-1,a,c,b)在执行else中的第二行 System.out.println最后执行move(n-1,b,c,a)执行move(2,a,c,b)时因为n!=1会在先执行一次else的所有叙所以才叫递回我觉得你先把程式是如何呼叫及执行先搞清楚在来提问比较好
作者: ilms49898723 (LittleBird)   2016-10-14 23:58:00
同楼上,我不懂你是不懂他递回的逻辑,还是你只是单纯看不懂code
作者: ssccg (23)   2016-10-15 01:57:00
如果你不懂method call stack的话,用debug一行一行跑反而会混乱以为都在哪几行跳吧先试着自己把执行顺序写出来,把method inline展开来看递回可能不是很重要,但是一个method call是怎么回事很重要
作者: pttworld (批踢踢世界)   2016-10-15 02:47:00
step into进入,step out跳出,step over跃往下一步。这三个基本的反复单步执行理解递回原理。
作者: gmoz ( This can't do that. )   2016-10-15 10:25:00
1进入 2进入 3进入 满足中断 3跑完返回 2跑完返回 1跑完返回先拿简单的例子弄清楚递回的运作方式
作者: adrianshum (Alien)   2016-10-15 16:55:00
很久以前我在c_cpp 版有回答过河内塔的问题,看看能不能理解?

Links booklink

Contact Us: admin [ a t ] ucptt.com