LC2049 - Count Nodes With the Highest Score

Description

There is a binary tree rooted at 0 consisting of n nodes. The nodes are labeled from 0 to n - 1. You are given a 0-indexed integer array parents representing the tree, where parents[i] is the parent of node i. Since node 0 is the root, parents[0] == -1.
Each node has a score. To find the score of a node, consider if the node and the edges connected to it were removed. The tree would become one or more non-empty subtrees. The size of a subtree is the number of the nodes in it. The score of the node is the product of the sizes of all those subtrees.
Return the number of nodes that have the highest score.

Example 1:

1
2
3
4
5
6
7
8
9
Input: parents = [-1,2,0,2,0]
Output: 3
Explanation:
- The score of node 0 is: 3 * 1 = 3
- The score of node 1 is: 4 = 4
- The score of node 2 is: 1 * 1 * 2 = 2
- The score of node 3 is: 4 = 4
- The score of node 4 is: 4 = 4
The highest score is 4, and three nodes (node 1, node 3, and node 4) have the highest score.

Example 2:

1
2
3
4
5
6
7
Input: parents = [-1,2,0]
Output: 2
Explanation:
- The score of node 0 is: 2 = 2
- The score of node 1 is: 2 = 2
- The score of node 2 is: 1 * 1 = 1
The highest score is 2, and two nodes (node 0 and node 1) have the highest score.

Constraints:
n == parents.length
2 <= n <= 105
parents[0] == -1
0 <= parents[i] <= n - 1 for i != 0
parents represents a valid binary tree.

Solutions

  1. Store the number of in-degree nodes for each node in degree
  2. Store the parent node and child node of the current node in two hash tables respectively
  3. The final answer is the product of the number of remaining nodes of the parent node to be deleted and the number of nodes of the self node.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
from collections import deque
class Solution:
def countHighestScoreNodes(self, parents: List[int]) -> int:
n = len(parents)
degree = [0]*n
fathers = defaultdict(list)
total = [1]*n
children = defaultdict(list)

for i, v in enumerate(parents[1:],1):
fathers[i].append(v)
children[v].append(i)
degree[v] += 1

queue = deque()
for i in range(n):
if degree[i] == 0:
queue.append(i)

while queue:
cur = queue.popleft()
for root in fathers[cur]:
total[root] += total[cur]
degree[root]-=1
if degree[root] == 0:
queue.append(root)

maxi, ans = 0, 0
for i in range(n):
cur = 1
for c in children[i]:
cur*=total[c]
if i != 0:
cur*=(total[0] - total[i])

if cur > maxi:
maxi = cur
ans = 1
elif cur == maxi:
ans +=1
return ans