Leetcode 1554 Solution
This article provides solution to leetcode question 1554 (minimum-time-to-collect-all-apples-in-a-tree).
Access this page by simply typing in "lcs 1554" in your browser address bar if you have bunnylol configured.
Leetcode Question Link
https://leetcode.com/problems/minimum-time-to-collect-all-apples-in-a-tree
Solution
class Solution:
def minTime(self, n: int, edges: List[List[int]], hasApple: List[bool]) -> int:
graph = collections.defaultdict(list)
for src, dst in edges:
graph[src].append(dst)
graph[dst].append(src)
apple_node_set = {i for i, apple in enumerate(hasApple) if apple}
visited = set()
def dfs(node):
if node in visited:
return False, 0
visited.add(node)
subtree_has_apple = node in apple_node_set
min_path = 0
for child in graph[node]:
child_subtree_has_apple, child_min_path = dfs(child)
subtree_has_apple |= child_subtree_has_apple
min_path += child_min_path + int(child_subtree_has_apple)
return subtree_has_apple, min_path
return dfs(0)[1] * 2