407889: GYM102916 M Binary Search Tree

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

Description

M. Binary Search Treetime limit per test2 secondsmemory limit per test512 megabytesinputstandard inputoutputstandard outputHow to check if a tree is a binary search tree?Someone in a Telegram chat

A binary search tree is a rooted tree, in which:

  • each vertex can have at most one left child and at most one right child,
  • for each non-leaf vertex $$$x$$$, all vertices in its left subtree are less than $$$x$$$. and all vertices in its right subtree are greater than $$$x$$$.

You are given a tree with $$$n$$$ vertices. Can this tree, being rooted at some vertex, be a binary search tree, and if it can, what vertices can be a root?

Input

The first line contains an integer $$$n$$$ ($$$1 \le n \le 500000$$$) — the number of vertices in the tree.

Each of the next $$$n - 1$$$ lines contains two integers $$$u_i$$$ and $$$v_i$$$ ($$$1 \le u_i, v_i \le n$$$) — the edges of the tree.

Output

If this tree can't be a binary search tree, output "-1".

Otherwise, output all vertices that can be a root, in increasing order.

ExamplesInput
3
1 2
2 3
Output
1 2 3 
Input
3
1 3
3 2
Output
1 
Input
4
1 3
3 2
2 4
Output
-1
Input
4
1 2
1 3
1 4
Output
-1

加入题单

上一题 下一题 算法标签: