Smuggling Marbles

AtCoder
IDarc086_c
Time3000ms
Memory256MB
Difficulty
Snuke has a rooted tree with $N+1$ vertices. The vertices are numbered $0$ through $N$, and Vertex $0$ is the root of the tree. The parent of Vertex $i$ $(1 \leq i \leq N)$ is Vertex $p_i$. Besides this tree, Snuke also has an box which is initially empty and many marbles, and playing with them. The play begins with placing one marble on some of the vertices, then proceeds as follows: 1. If there is a marble on Vertex $0$, move the marble into the box. 2. Move each marble from the vertex to its parent (all at once). 3. For each vertex occupied by two or more marbles, remove all the marbles from the vertex. 4. If there exists a vertex with some marbles, go to Step 1. Otherwise, end the play. There are $2^{N+1}$ ways to place marbles on some of the vertices. For each of them, find **the number of marbles that will be in the box at the end of the play**, and compute the sum of all those numbers modulo $1,000,000,007$. ## Constraints * $1 \leq N < 2 \times 10^{5}$ * $0 \leq p_i < i$ ## Input Input is given from Standard Input in the following format: $N$ $p_1$ $p_2$ $...$ $p_{N}$ ## Partial Scores * In the test set worth $400$ points, $N < 2{,}000$. [samples]
Samples
Input #1
2
0 0
Output #1
8

When we place a marble on both Vertex $1$ and $2$, there will be multiple marbles on Vertex $0$ by step 2. In such a case, these marbles will be removed instead of being moved to the box.
Input #2
5
0 1 1 0 4
Output #2
96
Input #3
31
0 1 0 2 4 0 4 1 6 4 3 9 7 3 7 2 15 6 12 10 12 16 5 3 20 1 25 20 23 24 23
Output #3
730395550

Be sure to compute the sum modulo $1,000,000,007$.
API Response (JSON)
{
  "problem": {
    "name": "Smuggling Marbles",
    "description": {
      "content": "Snuke has a rooted tree with $N+1$ vertices. The vertices are numbered $0$ through $N$, and Vertex $0$ is the root of the tree. The parent of Vertex $i$ $(1 \\leq i \\leq N)$ is Vertex $p_i$. Besides th",
      "description_type": "Markdown"
    },
    "platform": "AtCoder",
    "limit": {
      "time_limit": 3000,
      "memory_limit": 262144
    },
    "difficulty": "None",
    "is_remote": true,
    "is_sync": true,
    "sync_url": null,
    "sign": "arc086_c"
  },
  "statements": [
    {
      "statement_type": "Markdown",
      "content": "Snuke has a rooted tree with $N+1$ vertices. The vertices are numbered $0$ through $N$, and Vertex $0$ is the root of the tree. The parent of Vertex $i$ $(1 \\leq i \\leq N)$ is Vertex $p_i$.\nBesides th...",
      "is_translate": false,
      "language": "English"
    }
  ]
}
Full JSON Raw Segments