3761.Little Elephant and Tree

Time Limit: 1s Memory Limit: 256MB

The Little Elephant loves trees very much, he especially loves root trees.

He's got a tree consisting of n nodes (the nodes are numbered from 1 to n), with root at node number 1. Each node of the tree contains some list of numbers which initially is empty.

The Little Elephant wants to apply m operations. On the i-th operation (1 \le i \le m) he first adds number i to lists of all nodes of a subtree with the root in node number ai, and then he adds number i to lists of all nodes of the subtree with root in node bi.

After applying all operations the Little Elephant wants to count for each node i number ci - the number of integers j (1 \le j \le n;j \neq i), such that the lists of the i-th and the j-th nodes contain at least one common number.

Help the Little Elephant, count numbers ci for him.

Input Format(From the terminal/stdin)

The first line contains two integers n and m (1 \le n,m \le 105) - the number of the tree nodes and the number of operations.

Each of the following n-1 lines contains two space-separated integers, ui and vi (1 \le ui,vi \le n,ui \neq vi), that mean that there is an edge between nodes number ui and vi.

Each of the following m lines contains two space-separated integers, ai and bi (1 \le ai,bi \le n,ai \neq bi), that stand for the indexes of the nodes in the i-th operation.

It is guaranteed that the given graph is an undirected tree.

Output Format(To the terminal/stdout)

In a single line print n space-separated integers - c1,c2,...,cn.

Sample Input 1

Copy
5 1
1 2
1 3
3 5
3 4
2 3
 · \n
 · \n
 · \n
 · \n
 · \n
 · \n

Sample Output 1

Copy
0 3 3 3 3 
 · · · · \n

Sample Input 2

Copy
11 3
1 2
2 3
2 4
1 5
5 6
5 7
5 8
6 9
8 10
8 11
2 9
3 6
2 8
  · \n
 · \n
 · \n
 · \n
 · \n
 · \n
 · \n
 · \n
 · \n
 ·  \n
 ·  \n
 · \n
 · \n
 · \n

Sample Output 2

Copy
0 6 7 6 0 2 0 5 4 5 5 
 · · · · · · · · · · \n

Submit

请先 登录

© 2025 FAQs