LeetCode 107. Binary Tree Level Order Traversal II

简介: 给定二叉树,返回其节点值的自下而上级别顺序遍历。 (即,从左到右,逐下而上)。

v2-b3285f405d4bf98964c6bdbf6032326c_1440w.jpg

Description



Given a binary tree, return the bottom-up level order traversal of its nodes' values. (ie, from left to right, level by level from leaf to root).


For example:

Given binary tree [3,9,20,null,null,15,7],


3
   / \
  9  20
    /  \
   15   7


return its bottom-up level order traversal as:


[
  [15,7],
  [9,20],
  [3]
]


描述



给定二叉树,返回其节点值的自下而上级别顺序遍历。 (即,从左到右,逐下而上)。


思路



  • 此题目同第102题一样,都是要求按层遍历,第102题是从上往下,这一题要求从下往上.
  • 因此,我们仍然按层从上往下遍历,最后在把结果反转一次即可.
  • 我们使用队列,把下一层即将遍历的节点存储在队尾,这一层遍历的节点在队首,我们从队首取当前层的元素,直到当前层取完,我们进行下一层的遍历.


# -*- coding: utf-8 -*-
# @Author:             何睿
# @Create Date:        2018-12-30 12:13:55
# @Last Modified by:   何睿
# @Last Modified time: 2018-12-30 12:33:53
class TreeNode:
    def __init__(self, x):
        self.val = x
        self.left = None
        self.right = None
from collections import deque
class Solution:
    def levelOrderBottom(self, root):
        """
        :type root: TreeNode
        :rtype: List[List[int]]
        """
        if not root:
            return []
        res, queue, line = [], deque(), 0
        queue.append(root)
        while queue:
            line += 1
            # 当前层的节点个数
            count = len(queue)
            temp = []
            for _ in range(count):
                # 从左往右取当前层的节点
                top = queue.popleft()
                # 添加当前层节点的值
                temp.append(top.val)
                # 把当前层当前节点的左节点添加到队尾
                if top.left:
                    queue.append(top.left)
                # 把当前层当前节点的右节点添加到队尾
                if top.right:
                    queue.append(top.right)
            res.append(temp)
        # 最后倒转原来的顺序即可
        return [res.pop() for _ in range(line)]


源代码文件在这里.


目录
相关文章
|
6月前
Leetcode Minimum Depth of Binary Tree (面试题推荐)
计算树的最小深度 很简单的一道题,只需要遍历一次树,到叶子节点的时候计算一下深度和当前最小深度比较,保存最小值就行。 我在这用了一个全局变量 mindepth。总感觉我这代码写的不够简练,求更精简的方法。
25 0
|
6月前
Leetcode Binary Tree Postorder Traversal(面试题推荐)
非递后续归遍历二叉树,肯定得用到栈。先序遍历很好写,但后续遍历就不是那么容易了。 只需要设置个指针pre,指向最后输出的那个节点就行了,只要判断cur指针指向的是上次输出节点的父节点,且cur无其他未遍历的节点,这个时候就把cur节点输出即可,然后更改pre。原理是要遍历当前节点,其所有子节点都必须遍历完,因为肯定是先左后右,所以只需一个指针保持前一次输出的结果即可。
25 0
|
6月前
Leetcode 236. Lowest Common Ancestor of a Binary Tree
根据LCA的定义,二叉树中最小公共祖先就是两个节点p和q最近的共同祖先节点,LCA的定义没什么好解释的,主要是这道题的解法。
16 0
LeetCode contest 190 5418. 二叉树中的伪回文路径 Pseudo-Palindromic Paths in a Binary Tree
LeetCode contest 190 5418. 二叉树中的伪回文路径 Pseudo-Palindromic Paths in a Binary Tree
|
23小时前
|
算法 C++
【刷题】Leetcode 1609.奇偶树
这道题是我目前做过最难的题,虽然没有一遍做出来,但是参考大佬的代码,慢慢啃的感觉的真的很好。刷题继续!!!!!!
8 0
|
23小时前
|
算法 索引
【刷题】滑动窗口精通 — Leetcode 30. 串联所有单词的子串 | Leetcode 76. 最小覆盖子串
经过这两道题目的书写,相信大家一定深刻认识到了滑动窗口的使用方法!!! 下面请大家继续刷题吧!!!
11 0
|
23小时前
|
算法
【刷题】 leetcode 面试题 08.05.递归乘法
递归算法是一种在计算机科学和数学中广泛应用的解决问题的方法,其基本思想是利用问题的自我相似性,即将一个大问题分解为一个或多个相同或相似的小问题来解决。递归算法的核心在于函数(或过程)能够直接或间接地调用自身来求解问题的不同部分,直到达到基本情况(也称为基础案例或终止条件),这时可以直接得出答案而不必再进行递归调用。
25 4
【刷题】 leetcode 面试题 08.05.递归乘法
|
23小时前
|
存储 算法 安全
【刷题】 leetcode 面试题 01.06 字符串压缩
来看效果: 非常好!!!过啦!!!
25 5
【刷题】 leetcode 面试题 01.06 字符串压缩
|
23小时前
|
存储 算法 测试技术

热门文章

最新文章