二叉树遍历:考虑空节点

Posted r1-12king

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了二叉树遍历:考虑空节点相关的知识,希望对你有一定的参考价值。

思路:

  通常我们进行二叉树的遍历(前序遍历、中序遍历和后序遍历)时,不考虑空节点。但有时需要我们将空节点也放入遍历序列中。

  由于考虑了空节点,不能再用是否为空作为递归结束的条件。容易想到,只要一个节点非空,并且它的左右叶节点不同时为空,则其左右叶节点均要被遍历。这样我们就得到了考虑空节点的遍历。

  以中序遍历为例:
class TreeNode:
    def __init__(self, x):
        self.val = x
        self.left = None
        self.right = None

class Solution:
    def traval(self, root):
        if not root:
            return None
        global res
        res = []

        def mid_order(root):
            if root and (root.left or root.right):
                mid_order(root.left)
                res.append(root)
                mid_order(root.right)
            else:
                res.append(root)

        mid_order(root)

        return res

 

 

以上是关于二叉树遍历:考虑空节点的主要内容,如果未能解决你的问题,请参考以下文章

剑指offer 面试28题

java实现线索化二叉树的前序中序后续的遍历(完整代码)

Python 二叉树的创建和遍历、重建

讲透学烂二叉树:二叉树的遍历图解算法步骤及JS代码

二叉树的线索化

剑指offer第7题二叉树的下一个节点