Binary Tree Level Order Traversal II 두 갈래 나무의 등급 순서 2
Easy
두 갈래 나무를 지정하여 아래에서 위층으로 훑어보는 노드 값을 되돌려줍니다. (왼쪽에서 오른쪽으로, 잎에서 뿌리까지)
Example: 두 갈래 나무[3,9,20,null,null,15,7], 3/9 20/15 7 반환: [[15,7],[9,20,],[3]
이 문제는 전형적인 DFS(depth-first search) 알고리즘 문제입니다.귀속 방법을 사용할 수 있습니다.
여기서 관건은 루트 노드의 level을 통해 좌우가 아래로 흐를 때 동기적으로 추진할 수 있도록 제어하는 것이다.이 문제는 아래에서 위로 출력하기 때문에 결과에 대한 reverse가 필요합니다.
# 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 levelOrderBottom(self, root):
"""
:type root: TreeNode
:rtype: List[List[int]]
"""
res = []
self.dfs(root,0,res)
return res
def dfs(self, root, level, res):
if root:
if len(res) < level + 1:
res.insert(0,[])
res[-(level+1)].append(root.val)
self.dfs(root.left,level+1,res)
self.dfs(root.right,level+1,res)
dfs+stack
다음은 stack을 직접 활용하는 또 다른 해결 방안입니다.
def levelOrderBottom2(self, root):
stack = [(root, 0)]
res = []
while stack:
node, level = stack.pop()
if node:
if len(res) < level+1:
res.insert(0, [])
res[-(level+1)].append(node.val)
stack.append((node.right, level+1))
stack.append((node.left, level+1))
return res
bfs + queue
다음은 제3자 해결 방법입니다.queue를 이용하세요.
def levelOrderBottom(self, root):
queue, res = collections.deque([(root, 0)]), []
while queue:
node, level = queue.popleft()
if node:
if len(res) < level+1:
res.insert(0, [])
res[-(level+1)].append(node.val)
queue.append((node.left, level+1))
queue.append((node.right, level+1))
return res
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.