atcoder#AGC005E. [AGC005E] Sugigma: The Showdown
[AGC005E] Sugigma: The Showdown
Score : points
Problem Statement
Sigma and Sugim are playing a game.
The game is played on a graph with vertices numbered through . The graph has red edges and blue edges, and the edges in each color forms a tree. The red edges are represented by pairs of integers , and the blue edges are represented by pairs of integers .
Each player has his own piece. Initially, Sigma's piece is at vertex , and Sugim's piece is at vertex .
The game is played in turns, where turns are numbered starting from turn . Sigma takes turns , and Sugim takes turns .
In each turn, the current player either moves his piece, or does nothing. Here, Sigma can only move his piece to a vertex that is directly connected to the current vertex by a red edge. Similarly, Sugim can only move his piece to a vertex that is directly connected to the current vertex by a blue edge.
When the two pieces come to the same vertex, the game ends immediately. If the game ends just after the operation in turn , let be the total number of turns in the game.
Sigma's objective is to make the total number of turns as large as possible, while Sugim's objective is to make it as small as possible.
Determine whether the game will end in a finite number of turns, assuming both players plays optimally to achieve their respective objectives. If the answer is positive, find the number of turns in the game.
Constraints
- The edges in each color (red and blue) forms a tree.
Input
The input is given from Standard Input in the following format:
Output
If the game will end in a finite number of turns, print the number of turns.
Otherwise, print -1
.
4 1 2
1 2
1 3
1 4
2 1
2 3
1 4
4
3 3 1
1 2
2 3
1 2
2 3
4
4 1 2
1 2
3 4
2 4
1 2
3 4
1 3
2
4 2 1
1 2
3 4
2 4
1 2
3 4
1 3
-1
5 1 2
1 2
1 3
1 4
4 5
2 1
1 3
1 5
5 4
6