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

二叉树的下一个结点

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
            
全部评论

相关推荐

06-07 17:17
嘉兴学院 教师
心爱的idea:你孩
点赞 评论 收藏
分享
每晚夜里独自颤抖:你cet6就cet6,cet4就cet4,你写个cet证书等是什么意思。专业技能快赶上项目行数,你做的这2个项目哪里能提现你有这么多技能呢
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-01 11:47
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

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