给你二叉树的根节点 root ,返回其节点值 自底向上的层序遍历 。 (即按从叶子节点所在层到根节点所在的层,逐层从左向右遍历)
例:
输入:root = [3,9,20,null,null,15,7]
输出:[[15,7],[9,20],[3]]
解析:
先层序遍历然后,将列表里的值进行翻转即可。层序遍历可看这篇:二叉树的层序遍历Python解法_皮_客的博客-CSDN博客给你二叉树的根节点 root ,返回其节点值的 层序遍历 。 (即逐层地,从左到右访问所有节点)。例:输入:root = [3,9,20,null,null,15,7]输出:[[3],[9,20],[15,7]]解析:运用队列的思想。每次大循环就是一层,每从队列中出队一个数就将他的子节点加入队列,每一层便利玩就将便利的值加入结果中。# Definition for a binary tree node.# class TreeNode(object):# def _https://blog.csdn.net/qq_43593534/article/details/123800081
# Definition for a binary tree node.
# class TreeNode(object):
# def __init__(self, val=0, left=None, right=None):
# self.val = val
# self.left = left
# self.right = right
class Solution(object):
def levelOrderBottom(self, root):
"""
:type root: TreeNode
:rtype: List[List[int]]
"""
res = []
if root:
queue = [root]
else:
return res
while len(queue):
n = len(queue)
r = []
for _ in range(n):
node = queue.pop(0)
r.append(node.val)
if node.left:
queue.append(node.left)
if node.right:
queue.append(node.right)
res.append(r)
res = res[::-1] # 翻转
return res
|