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)]


源代码文件在这里.


目录
相关文章
|
Java
Leetcode 114. Flatten Binary Tree to Linked List
思路也很简单,先把root的左子树(如有)变成单链表 leftlinkedlist,把root的右子树(如有)变成单链表 rightlinkedlist,再把root的右节点变成leftlikedlist,再把rightlinkedlist接到leftlinkedlist后面,代码如下。
45 1
Leetcode Minimum Depth of Binary Tree (面试题推荐)
计算树的最小深度 很简单的一道题,只需要遍历一次树,到叶子节点的时候计算一下深度和当前最小深度比较,保存最小值就行。 我在这用了一个全局变量 mindepth。总感觉我这代码写的不够简练,求更精简的方法。
47 0
Leetcode 236. Lowest Common Ancestor of a Binary Tree
根据LCA的定义,二叉树中最小公共祖先就是两个节点p和q最近的共同祖先节点,LCA的定义没什么好解释的,主要是这道题的解法。
38 0
Leetcode 623. Add One Row to Tree
题目很简单,在树的第d层加一层,值为v。递归增加一层就好了。代码如下
47 0
|
2月前
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
|
3月前
|
Python
【Leetcode刷题Python】剑指 Offer 32 - III. 从上到下打印二叉树 III
本文介绍了两种Python实现方法,用于按照之字形顺序打印二叉树的层次遍历结果,实现了在奇数层正序、偶数层反序打印节点的功能。
57 6
|
3月前
|
搜索推荐 索引 Python
【Leetcode刷题Python】牛客. 数组中未出现的最小正整数
本文介绍了牛客网题目"数组中未出现的最小正整数"的解法,提供了一种满足O(n)时间复杂度和O(1)空间复杂度要求的原地排序算法,并给出了Python实现代码。
114 2
|
21天前
|
机器学习/深度学习 人工智能 自然语言处理
280页PDF,全方位评估OpenAI o1,Leetcode刷题准确率竟这么高
【10月更文挑战第24天】近年来,OpenAI的o1模型在大型语言模型(LLMs)中脱颖而出,展现出卓越的推理能力和知识整合能力。基于Transformer架构,o1模型采用了链式思维和强化学习等先进技术,显著提升了其在编程竞赛、医学影像报告生成、数学问题解决、自然语言推理和芯片设计等领域的表现。本文将全面评估o1模型的性能及其对AI研究和应用的潜在影响。
16 1
|
2月前
|
数据采集 负载均衡 安全
LeetCode刷题 多线程编程九则 | 1188. 设计有限阻塞队列 1242. 多线程网页爬虫 1279. 红绿灯路口
本文提供了多个多线程编程问题的解决方案,包括设计有限阻塞队列、多线程网页爬虫、红绿灯路口等,每个问题都给出了至少一种实现方法,涵盖了互斥锁、条件变量、信号量等线程同步机制的使用。
LeetCode刷题 多线程编程九则 | 1188. 设计有限阻塞队列 1242. 多线程网页爬虫 1279. 红绿灯路口
|
3月前
|
索引 Python
【Leetcode刷题Python】从列表list中创建一颗二叉树
本文介绍了如何使用Python递归函数从列表中创建二叉树,其中每个节点的左右子节点索引分别是当前节点索引的2倍加1和2倍加2。
57 7