CF765E.Tree Folding
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
Vanya wants to minimize a tree. He can perform the following operation multiple times: choose a vertex v , and two disjoint (except for v ) paths of equal length a0=v , a1 , ..., ak , and b0=v , b1 , ..., bk . Additionally, vertices a1 , ..., ak , b1 , ..., bk must not have any neighbours in the tree other than adjacent vertices of corresponding paths. After that, one of the paths may be merged into the other, that is, the vertices b1 , ..., bk can be effectively erased:
Help Vanya determine if it possible to make the tree into a path via a sequence of described operations, and if the answer is positive, also determine the shortest length of such path.
输入格式
The first line of input contains the number of vertices n ( 2<=n<=2⋅105 ).
Next n−1 lines describe edges of the tree. Each of these lines contains two space-separated integers u and v ( 1<=u,v<=n , u=v ) — indices of endpoints of the corresponding edge. It is guaranteed that the given graph is a tree.
输出格式
If it is impossible to obtain a path, print -1. Otherwise, print the minimum number of edges in a possible path.
输入输出样例
输入#1
6 1 2 2 3 2 4 4 5 1 6
输出#1
3
输入#2
7 1 2 1 3 3 4 1 5 5 6 6 7
输出#2
-1
说明/提示
In the first sample case, a path of three edges is obtained after merging paths 2−1−6 and 2−4−5 .
It is impossible to perform any operation in the second sample case. For example, it is impossible to merge paths 1−3−4 and 1−5−6 , since vertex 6 additionally has a neighbour 7 that is not present in the corresponding path.