Codeforces Round 922 (Div. 2) |
---|
Finished |
The caterpillar decided to visit every node of the tree. Initially, it is sitting at the root.
The tree is represented as a rooted tree with the root at the node $$$1$$$. Each crawl to a neighboring node takes $$$1$$$ minute for the caterpillar.
And there is a trampoline under the tree. If the caterpillar detaches from the tree and falls onto the trampoline, it will end up at the root of the tree in $$$0$$$ seconds. But the trampoline is old and can withstand no more than $$$k$$$ caterpillar's falls.
What is the minimum time the caterpillar can take to visit all the nodes of the tree?
More formally, we need to find the minimum time required to visit all the nodes of the tree, if the caterpillar starts at the root (node $$$1$$$) and moves using two methods.
The second method (teleportation) can be used at most $$$k$$$ times. The caterpillar can finish the journey at any node.
The first line of the input contains two integers: $$$n$$$ ($$$2 \le n \le 2\cdot 10^5$$$) — the number of nodes in the tree, and $$$k$$$ ($$$0 \le k \le 10^9$$$) — the maximum number of teleports to the root.
The second line contains $$$n-1$$$ integers $$$p_2$$$, $$$p_3$$$, ..., $$$p_n$$$ ($$$1 \le p_i \le n$$$) — the ancestors in the tree for nodes $$$2, 3, \ldots, n$$$; node $$$1$$$ is the root.
Print a single number in a single line — the minimum number of minutes required to visit all the nodes of the tree.
8 1 1 1 2 2 4 3 3
9
4 0 4 4 1
4
The figure shows one of the ways to traverse the tree from the first test in 9 minutes.
Name |
---|