纯静态网站开发,做面食的网站,居然之家装修公司官网,四川建设银行手机银行下载官方网站下载安装题目描述
汉诺塔是约19世纪末#xff0c;在欧州的商店中出售一种智力玩具。它的结构如下图所示#xff1a; 在一个平板上立有三根铁针#xff0c;分别记为A, B, C。开始时#xff0c;铁针 A 上依次叠放着从大到小 n 个圆盘#xff0c;游戏的目标就是将 A 上的 n 个圆盘…题目描述
汉诺塔是约19世纪末在欧州的商店中出售一种智力玩具。它的结构如下图所示 在一个平板上立有三根铁针分别记为A, B, C。开始时铁针 A 上依次叠放着从大到小 n 个圆盘游戏的目标就是将 A 上的 n 个圆盘全部转移到 C 上要求每次只能移动某根铁针最上层一个圆盘圆盘不得放在这三根铁针以外的任何地方而且永远只能将小的圆盘叠放在大的圆盘之上。
例如下面就是示例输出中n 3移动方案的图示 这是一个著名的问题几乎所有的教材上都有这个问题。由于条件是一次只能移动一个盘且不允许大盘放在小盘上面所以 64 个盘的移动次数是 18,446,744,073,709,551,615 这是一个天文数字若每一微秒可能做一次移动那么也需要几乎一百万年。我们仅能找出问题的解决方法并解决较小 n 值时的汉诺塔但很难用计算机解决64层的汉诺塔。
关于输入
输入数据只有一个正整数 n (n 16) 表示开始时铁针 A 上的圆盘数
关于输出
要求输出步数最少的搬动方案方案是由若干个步骤构成的输出的每行就表示一个移动步骤例如“A-B”就表示把铁针 A 最上层的一个圆盘移动到 B 上。
代码实现
#include iostream
using namespace std;void move(char a,char b){cout盘子从a移动到bendl;
}void f(int n,char a,char b,char c){if(n1){move(a,c);count;return;}else{f(n-1,a,c,b);move(a,c);count;f(n-1,b,a,c);}
}int main() {int n; cinn;f(n,A,B,C);return 0;
}