-
Notifications
You must be signed in to change notification settings - Fork 17
Expand file tree
/
Copy pathaverage_levels_of_binary_tree.py
More file actions
34 lines (30 loc) · 988 Bytes
/
average_levels_of_binary_tree.py
File metadata and controls
34 lines (30 loc) · 988 Bytes
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
# Definition for a binary tree node.
from typing import List
from collections import deque
class TreeNode:
def __init__(self, val=0, left=None, right=None):
self.val = val
self.left = left
self.right = right
class Solution:
def averageOfLevels(self, root: TreeNode) -> List[float]:
result = [0]
queue = deque()
queue.append(root)
queue.append(None)
count = 0
while queue:
current = queue.popleft()
if current is None and len(queue) == 0: break
if current is None:
queue.append(None)
result[-1] /= count
result.append(0)
count = 0
continue
count += 1
if current.left is not None: queue.append(current.left)
if current.right is not None: queue.append(current.right)
result[-1] += current.val
result[-1] /= count
return result