Notice: Undefined index: name in /usr/www/lib/views/home/viewtitle.html on line 188
-完善程序 第 20 题
(汉诺塔问题)给定三根柱子,分别标记为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 题 ⑸处应填( )。

解答部分以后会开放。