#D9603. You Are Given a Tree

    ID: 7982 Type: Default 7000ms 512MiB

You Are Given a Tree

You Are Given a Tree

A tree is an undirected graph with exactly one simple path between each pair of vertices. We call a set of simple paths k-valid if each vertex of the tree belongs to no more than one of these paths (including endpoints) and each path consists of exactly k vertices.

You are given a tree with n vertices. For each k from 1 to n inclusive find what is the maximum possible size of a k-valid set of simple paths.

Input

The first line of the input contains a single integer n (2 ≤ n ≤ 100 000) — the number of vertices in the tree.

Then following n - 1 lines describe the tree, each of them contains two integers v, u (1 ≤ v, u ≤ n) — endpoints of the corresponding edge.

It is guaranteed, that the given graph is a tree.

Output

Output n numbers, the i-th of which is the maximum possible number of paths in an i-valid set of paths.

Examples

Input

7 1 2 2 3 3 4 4 5 5 6 6 7

Output

7 3 2 1 1 1 1

Input

6 1 2 2 3 2 4 1 5 5 6

Output

6 2 2 1 1 0

Note

One way to achieve the optimal number of paths for the second sample is illustrated in the following picture:

inputFormat

Input

The first line of the input contains a single integer n (2 ≤ n ≤ 100 000) — the number of vertices in the tree.

Then following n - 1 lines describe the tree, each of them contains two integers v, u (1 ≤ v, u ≤ n) — endpoints of the corresponding edge.

It is guaranteed, that the given graph is a tree.

outputFormat

Output

Output n numbers, the i-th of which is the maximum possible number of paths in an i-valid set of paths.

Examples

Input

7 1 2 2 3 3 4 4 5 5 6 6 7

Output

7 3 2 1 1 1 1

Input

6 1 2 2 3 2 4 1 5 5 6

Output

6 2 2 1 1 0

Note

One way to achieve the optimal number of paths for the second sample is illustrated in the following picture:

样例

6
1 2
2 3
2 4
1 5
5 6
6

2 2 1 1 0

</p>