不是VIP会员,不能显示答案

题目解答

题目:
(汉诺塔问题)给定三根柱子,分别标记为A、B和C。初始状态下,柱子A上有若干个圆盘,这些圆盘从上到下按从小到大的顺序排列。任务是将这些圆盘全部移到柱子c上,且必须保持原有顺序不变。在移动过程中,需要遵守以不规则:

1.只能从一根柱子的顶部取出圆盘,并将其放入另一根柱子的顶部。

2.每次只能移动一个圆盘

3.小圆盘必须始终在大圆盘之上。

试补全程序

#include <bits/stdc++.h>

using namespace std;



void move(char src, char tgt) {

cout << "从柱子" << src << "挪到柱子上" << tgt << endl;

}



void dfs(int i, char src, char tmp, char tgt) {

if(i == __(1)__ ) {

move( __(2)__ );

return;

}

dfs(i-1, __(3)__ );

move(src, tgt);

dfs( __(5)__ , __(4)__ );

}



int main() {

int n;

cin >> n;

dfs(n, 'A', 'B', 'C');

}


选择题

1) ⑴处应填( )。

2) ⑵处应填( )。

3) ⑶处应填( )。

4) ⑷处应填( )。

5) ⑸处应填( )。
考点:
分析:
解答:
评论:
老师: