题目:
给定一个二叉树,返回其节点值自底向上的层次遍历。 (即按从叶子节点所在层到根节点所在的层,逐层从左向右遍历)
例如:
给定二叉树 [3,9,20,null,null,15,7],
3
/ \
9 20
/ \
15 7
返回其自底向上的层次遍历为:
[
[15,7],
[9,20],
[3]
]
python代码:
class Solution:
def preorder(self, root, level, res):
if root:
if len(res) < level+1: res.append([])
res[level].append(root.val)
self.preorder(root.left, level+1, res)
self.preorder(root.right, level+1, res)
def levelOrderBottom(self, root):
res=[]
self.preorder(root, 0, res)
return res[::-1]
心得:和树相关的题总是用递归更容易解,但是树很深时比较费时间。
本文介绍了一种二叉树的遍历方法——自底向上的层次遍历,并提供了一个Python实现示例。该方法从叶子节点开始逐层向上遍历至根节点,适用于需要逆序获取树结构信息的场景。
1565

被折叠的 条评论
为什么被折叠?



