简单汉诺塔问题
该比赛已结束,您无法在比赛模式下递交该题目。您可以点击“在题库中打开”以普通模式查看和递交本题。
背景
汉诺塔(又称河内塔)问题是源于印度一个古老传说的益智玩具。大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘。
题目描述
现有A
,B
,C
三个圆盘,A
上有N
(N>=3
)个从上向下按照由小到大顺序排列的圆盘,规定小盘必须在大盘上面,且每次只能挪动一个盘子,问:要将所有盘子按原来排布从A
挪至C
需要如何操作?
输入格式
一个正整数N
,代表初始状态下A
上有多少盘子
输出格式
共M
行(M
代表操作总次数)
每一行用X->Y
代表把X
顶部的盘子移至Y
输入样例
3
输出样例
A->C
A->B
C->B
A->C
B->A
B->C
A->C
数据范围
100%的数据,N<=17
限制
每个测试点时间1秒,内存128MiB