HANOICAL - Hanoi Calls

no tags 

Theory:

  • Towers of Hanoi is an arrangement consisting of three pegs and N discs of radius 1 to N.
  • Each peg can hold zero or more discs, but at any point of time, the radius of the discs must be in decreasing order from bottom to top.
  • A move consists of moving the topmost disc from one peg to another. After the move, the descending order property of pegs must hold.

Traditional problem is: If all discs are stacked up on peg #1, how many moves will it take to move all the discs to peg #2?

Recursive solution: Noting that for disc N to move, from peg #a to peg #b, all discs of size 1 to N-1 must be in peg #c. Hence there is exactly one minimal way to move the discs. After disc N has moved, all pegs from #c must be moved back to #a.

If moves(N) denote the number of moves required to transfer N discs between two pegs (both sorted configuration), then moves(N) = moves(N-1) + 1 + moves(N-1); Solving the recurrence yields moves(N) = 2N -1; The idea I am trying to share is that, there is exactly one such move sequence.

Now the problem is that given any initial configuration of the discs, and any final configuration, Can you tell me the minimal number of moves required to change it from initial to final configuration?

Input

The input file consists of about 100 test cases.

The first line of each test case contains one integer, N (1 ≤ N ≤ 30)

The second line of each test case contains N integers, each one of which will be between 1 and 3. The i-th integer tells you the peg number at which disc of radius i is present in the initial configuration.

The third line contains a similar specification for the final configuration.

Input terminates with a line containing a single zero, which must not be processed.

Output

For each test case print one line containing a single integer, which is the minimal number of moves to make the transfer.

Example

Input:
4
1 1 1 1
2 2 2 2
3
1 3 3
2 1 1
5
1 3 2 2 2
2 3 2 1 2
0

Output
15
6
14

Explanation

Test case #1: This is the moves(4) = 24 - 1;

Test case #2:

   [peg1, peg2, peg3] =
#0 [ {1}, {}, {3,2} ]
#1 [ {1}, {2}, {3}  ]
#2 [ {}, {2,1}, {3} ]
#3 [ {3}, {2,1}, {} ]
#4 [ {3}, {2}, {1}  ]
#5 [ {3,2}, {}, {1} ]
#6 [ {3,2}, {1}, {} ]


Added by:Prasanna
Date:2007-10-08
Time limit:1s
Source limit:50000B
Memory limit:1536MB
Cluster: Cube (Intel G860)
Languages:All except: ERL JS-RHINO NODEJS PERL6 VB.NET
Resource:NITT ACM ICPC Local Contest 2007 [Self/Traditional]