ADA Training CP
Tree Painting
You are given a tree (an undirected connected acyclic graph) consisting of n vertices. You are playing a game on this tree.
Initially, all vertices are white. On the first turn of the game you choose one vertex and paint it black. Then on each turn you choose a white vertex adjacent (connected by an edge) to any black vertex and paint it black.
Each time you choose a vertex (even during the first turn), you gain a number of points equal to the size of the connected component consisting only of white vertices that contains the chosen vertex. The game ends when all vertices are painted black.
Let's see the following example:

Vertices 1 and 4 are painted black already. If you choose vertex 2, you will gain 4 points for the connected component consisting of vertices 2, 3, 5 and 6. If you choose vertex 9, you will gain 3 points for the connected component consisting of vertices 7, 8 and 9.
Your task is to maximize the number of points you gain.
Input data
The first line contains an integer n (2 ≤ n ≤ 2 * 10^5
) - the number of vertices in the tree.
Each of the next n - 1 lines describes an edge of the tree. Edge i is denoted by two integers u[i]
and v[i]
(1 ≤ u[i]
, v[i]
≤ n, u[i]
≠ v[i]
), the indices of vertices it connects.
It is guaranteed that the given edges form a tree.
Output data
Print one integer - the maximum number of points you gain if you play optimally.
Examples
9 1 2 2 3 2 5 2 6 1 4 4 9 9 7 9 8
36
5 1 2 1 3 2 4 2 5
14