CF98D.Help Monks

普及/提高-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

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 nn 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 2n12^{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 nn — the number of disks ( 1<=n<=201<=n<=20 ). The second line contains nn integers did_{i} — the disks' diameters after Ku Sean Sun cut their edges. The diameters are given from the bottom to the top ( 1<=di<=201<=d_{i}<=20 , besides, di>=di+1d_{i}>=d_{i+1} for any 1<=i<n ).

输出格式

Print on the first line number mm — the smallest number of moves to solve the gods' problem. Print on the next mm lines the description of moves: two space-separated positive integers sis_{i} and tit_{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<=si,ti<=31<=s_{i},t_{i}<=3 , sitis_{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).

首页