[問題] 河內塔問題

作者: MBS550L (li)   2020-11-11 02:11:36
大家好
小弟過幾天資結期中考
正在研究河內塔的問題
剛剛使用這個網站跑程式碼(文末附上)
http://pythontutor.com/cpp.html#mode=display
卻發現有一個地方很奇怪
為何第七步驟明明還在呼叫第八行的函式hanoi(n-1,A,C,B)
而第八行可視化後的結果是A=A B=B C=C
有大大能幫我解答嗎 我卡了好久..
==============================
1#include <stdio.h>
2
3void hanoi(int n, char A, char B, char C) {
4 if(n == 1) {
5 printf("Move sheet from %c to %c\n", A, C);
6 }
7 else {
8 hanoi(n-1, A, C, B);
9 hanoi(1, A, B, C);
10 hanoi(n-1, B, A, C);
11 }
12}
13
14int main() {
15
16 hanoi(3, 'A', 'B', 'C');
17 return 0;
18}
作者: springman (司布林)   2020-11-11 04:15:00
「第八行可視化後的結果是A=A B=B C=C」這時是 n=1將第一個盤子從 A 移到 C,是第一個移動的動作。有什麼問題嗎?
作者: LPH66 (-6.2598534e+18f)   2020-11-11 07:24:00
對於遞迴的一個重要觀念: 每次呼叫都是獨立作業呼叫自己可以想成叫另一個自己起來做事, 等他做完再繼續
作者: sarafciel (Cattuz)   2020-11-11 16:26:00
https://imgur.com/wVPKTO6注意紅色箭頭指的是"next line to execution"所以這時候第8行還沒進去 你看到的是第一次呼叫的stack

Links booklink

Contact Us: admin [ a t ] ucptt.com