300513: CF98D. Help Monks

Memory Limit:256 MB Time Limit:2 S
Judge Style:Text Compare Creator:
Submit:0 Solved:0

Description

Help Monks

题意翻译

这是一个汉诺塔问题的加强版。在本问题中,圆盘的直径可以相同。现要将$n$个圆盘从$1$号柱移动到$3$号柱上,允许将直径相同的一个圆盘放置在另一个上,**但是圆盘最终放置在$3$号柱上的顺序应与$1$号柱上圆盘的初始顺序相同**(样例$3$)。 现给出$1$号柱的初始圆盘数量$n$并从下到上给出$1$号柱上的圆盘大小,求将其移动到$3$号柱上最小的移动次数并输出路径。

题目描述

In a far away kingdom is the famous Lio Shan monastery. Gods constructed three diamond pillars on the monastery's lawn long ago. Gods also placed on one pillar $ n $ golden disks of different diameters (in the order of the diameters' decreasing from the bottom to the top). Besides, gods commanded to carry all the disks from the first pillar to the third one according to the following rules: - you can carry only one disk in one move; - you cannot put a larger disk on a smaller one. There was no universal opinion concerning what is to happen after the gods' will is done: some people promised world peace and eternal happiness to everyone, whereas others predicted that the kingdom will face communi… (gee, what am I rambling about?) the Armageddon. However, as everybody knew that it was impossible to solve the problem in less than $ 2^{n}-1 $ moves and the lazy Lio Shan monks never even started to solve it, everyone lives peacefully even though the problem was never solved and nobody was afraid of the Armageddon.However, the monastery wasn't doing so well lately and the wise prior Ku Sean Sun had to cut some disks at the edges and use the gold for the greater good. Wouldn't you think that the prior is entitled to have an air conditioning system? Besides, staying in the monastery all year is sooo dull… One has to have a go at something new now and then, go skiing, for example… Ku Sean Sun realize how big a mistake he had made only after a while: after he cut the edges, the diameters of some disks got the same; that means that some moves that used to be impossible to make, were at last possible (why, gods never prohibited to put a disk on a disk of the same diameter). Thus, the possible Armageddon can come earlier than was initially planned by gods. Much earlier. So much earlier, in fact, that Ku Sean Sun won't even have time to ski all he wants or relax under the air conditioner. The wise prior could never let that last thing happen and he asked one very old and very wise witch PikiWedia to help him. May be she can determine the least number of moves needed to solve the gods' problem. However, the witch laid out her cards and found no answer for the prior. Then he asked you to help him. Can you find the shortest solution of the problem, given the number of disks and their diameters? Keep in mind that it is allowed to place disks of the same diameter one on the other one, however, the order in which the disks are positioned on the third pillar in the end should match the initial order of the disks on the first pillar.

输入输出格式

输入格式


The first line contains an integer $ n $ — the number of disks ( $ 1<=n<=20 $ ). The second line contains $ n $ integers $ d_{i} $ — the disks' diameters after Ku Sean Sun cut their edges. The diameters are given from the bottom to the top ( $ 1<=d_{i}<=20 $ , besides, $ d_{i}>=d_{i+1} $ for any $ 1<=i&lt;n $ ).

输出格式


Print on the first line number $ m $ — the smallest number of moves to solve the gods' problem. Print on the next $ m $ lines the description of moves: two space-separated positive integers $ s_{i} $ and $ t_{i} $ that determine the number of the pillar from which the disk is moved and the number of pillar where the disk is moved, correspondingly ( $ 1<=s_{i},t_{i}<=3 $ , $ s_{i}≠t_{i} $ ).

输入输出样例

输入样例 #1

3
3 2 1

输出样例 #1

7
1 3
1 2
3 2
1 3
2 1
2 3
1 3

输入样例 #2

3
3 1 1

输出样例 #2

5
1 2
1 2
1 3
2 3
2 3

输入样例 #3

3
3 3 3

输出样例 #3

5
1 2
1 2
1 3
2 3
2 3

说明

Pay attention to the third test demonstrating that the order of disks should remain the same in the end, even despite the disks' same radius. If this condition was not necessary to fulfill, the gods' task could have been solved within a smaller number of moves (three — simply moving the three disks from the first pillar on the third one).

Input

题意翻译

这是一个汉诺塔问题的加强版。在本问题中,圆盘的直径可以相同。现要将$n$个圆盘从$1$号柱移动到$3$号柱上,允许将直径相同的一个圆盘放置在另一个上,**但是圆盘最终放置在$3$号柱上的顺序应与$1$号柱上圆盘的初始顺序相同**(样例$3$)。 现给出$1$号柱的初始圆盘数量$n$并从下到上给出$1$号柱上的圆盘大小,求将其移动到$3$号柱上最小的移动次数并输出路径。

加入题单

算法标签: