题解 | #二叉树的下一个结点#

二叉树的下一个结点

http://www.nowcoder.com/practice/9023a0c988684a53960365b889ceaf5e

一、思路

分两种情况 (1)当前节点有右孩子,那么就去找当前节点右子树最左边的那个孩子节点 (2)当前节点没有右孩子,那么向上找父节点 -若当前节点是其父节点的左孩子,那么直接返回父节点 -若当前节点不是其父节点的左孩子,那么循环向上查找一直到满足当前节点是其父节点的左孩子的情况为止

# class TreeLinkNode:
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None
#         self.next = None
class Solution:
    def GetNext(self, pNode):
        # write code here
        if not pNode:
            return pNode
        #当前节点有右孩子,那么就去找当前节点右子树最左边的那个孩子节点
        if pNode.right:
            pNode = pNode.right
            while pNode.left:
                pNode = pNode.left
            return pNode
        #当前节点没有右孩子,那么向上找父节点
        while pNode.next:
            root = pNode.next
            if root.left == pNode:
                return root 
            pNode = pNode.next
        return None
            
全部评论

相关推荐

程序员牛肉:继续沉淀吧同学,你这就是纯纯的流水线产品。 差不多的学历+两个烂大街项目。自身学历又不行,现在找啥实习呢。有点太浮躁了。多花点心思搞搞ai,开源和八股。这比你这段时间捣鼓一段小厂实习要好得多;
点赞 评论 收藏
分享
12-19 20:28
已编辑
门头沟学院 Java
美团履约 全栈工程师 (n+1)*15.5 其他
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务