Skip to content

Commit e13bf2a

Browse files
authored
Create vertical-order-traversal-of-a-binary-tree.py
1 parent 4ecb0b9 commit e13bf2a

File tree

1 file changed

+34
-0
lines changed

1 file changed

+34
-0
lines changed
Lines changed: 34 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,34 @@
1+
# Time: O(nlogn)
2+
# Space: O(n)
3+
4+
# Definition for a binary tree node.
5+
class TreeNode(object):
6+
def __init__(self, x):
7+
self.val = x
8+
self.left = None
9+
self.right = None
10+
11+
12+
class Solution(object):
13+
def verticalTraversal(self, root):
14+
"""
15+
:type root: TreeNode
16+
:rtype: List[List[int]]
17+
"""
18+
def dfs(node, lookup, x, y):
19+
if not node:
20+
return
21+
lookup[x][y].append(node)
22+
dfs(node.left, lookup, x-1, y+1)
23+
dfs(node.right, lookup, x+1, y+1)
24+
25+
lookup = collections.defaultdict(lambda: collections.defaultdict(list))
26+
dfs(root, lookup, 0, 0)
27+
28+
result = []
29+
for x in sorted(lookup):
30+
report = []
31+
for y in sorted(lookup[x]):
32+
report.extend(sorted(node.val for node in lookup[x][y]))
33+
result.append(report)
34+
return result

0 commit comments

Comments
 (0)