代码拉取完成,页面将自动刷新
# Time: O(nlogn)
# Space: O(n)
import collections
# Definition for a binary tree node.
class TreeNode(object):
def __init__(self, x):
self.val = x
self.left = None
self.right = None
class Solution(object):
def verticalTraversal(self, root):
"""
:type root: TreeNode
:rtype: List[List[int]]
"""
def dfs(node, lookup, x, y):
if not node:
return
lookup[x][y].append(node)
dfs(node.left, lookup, x-1, y+1)
dfs(node.right, lookup, x+1, y+1)
lookup = collections.defaultdict(lambda: collections.defaultdict(list))
dfs(root, lookup, 0, 0)
result = []
for x in sorted(lookup):
report = []
for y in sorted(lookup[x]):
report.extend(sorted(node.val for node in lookup[x][y]))
result.append(report)
return result
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。