原题
https://leetcode.cn/problems/binary-tree-level-order-traversal-ii/description/
思路
广度优先 + 栈
复杂度
时间:O(n)
空间:O(n)
Python代码
# Definition for a binary tree node.
# class TreeNode:
# def __init__(self, val=0, left=None, right=None):
# self.val = val
# self.left = left
# self.right = right
class Solution:
def levelOrderBottom(self, root: Optional[TreeNode]) -> List[List[int]]:
ans = []
if not root:
return ans
q = [root]
while q:
level = []
for i in range(len(q)):
node = q.pop(0)
level.append(node.val)
if node.left:
q.append(node.left)
if node.right:
q.append(node.right)
ans.append(level)
return ans[::-1]
Go代码
/**
* Definition for a binary tree node.
* type TreeNode struct {
* Val int
* Left *TreeNode
* Right *TreeNode
* }
*/
func levelOrderBottom(root *TreeNode) [][]int {
var ans [][]int
if root == nil {
return ans
}
q := []*TreeNode{root}
for len(q) > 0 {
// 当前层的节点值切片
level := []int{}
n := len(q)
for i := 0; i < n; i++ {
node := q[0]
// 出栈
q = q[1:]
level = append(level, node.Val)
if node.Left != nil {
q = append(q, node.Left)
}
if node.Right != nil {
q = append(q, node.Right)
}
}
// 入栈
ans = slices.Insert(ans, 0, level)
}
return ans
}
167

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



