剑指Offer57 二叉树的下一个节点

Java 题解

     a
    / \
   b   c
  / \ / \
 d  e f  g
   / \
  h   i

情形 1

如果一个节点有右子树,那么他的下一个节点就是他的右子树的最左子节点(从右子节点出发一直沿着指向左子节点的指针就能找到他的下一个子节点),如:a的下一个节点就是d。

情形 2

如果一个节点没有右子树,且此节点是他的父节点的左子节点,他的下一个节点就是他的父节点,如:节点d的下一个节点是b。

情形 3

如果一个节点既没有右子树,且此节点又是父节点的右子节点。我们可以沿着此节点指向父节点的指针一直向上遍历,直到找到一个是他父节点的左子节点的节点,如:i节点的下一个节点,沿着他的父节点的指针遍历,先到达e,但是e是他父节点b的右子节点,所以继续向上,到达b节点,b是他父节点a的左子节点,所以i的下一个节点是a。

public class Solution {
    public TreeLinkNode GetNext(TreeLinkNode pNode)
    {
        if(pNode == null)
            return null;

        TreeLinkNode pNext = null;

        // 情形 1
        // 如果一个节点有右子树,那么他的下一个节点就是他的右子树的最左子节点
        // (从右子节点出发一直沿着指向左子节点的指针就能找到他的下一个子节点)
        if(pNode.right != null){
            TreeLinkNode pRight = pNode.right;
            while(pRight.left!=null){
                pRight = pRight.left;
            }
            pNext = pRight;
        }else if(pNode.next != null){
            // 情形 2
            // 如果一个节点没有右子树,且此节点是他的父节点的左子节点,他的下一个节点就是他的父节点
            if(pNode.next.left == pNode){
                pNext = pNode.next;
            }

            // 情形3
            // 如果一个节点既没有右子树,且此节点又是父节点的右子节点。
            // 我们可以沿着此节点指向父节点的指针一直向上遍历,直到找到一个是他父节点的左子节点的节点,
            else {
                TreeLinkNode curr = pNode;
                TreeLinkNode pParent = pNode.next;
                while(pParent!=null && curr == pParent.right){
                    curr = pParent;
                    pParent = pParent.next;
                }
                pNext = pParent;
            }

        }
        return pNext;
    }
}
全部评论

相关推荐

10-21 16:54
门头沟学院 Java
后端转测开第一人:微服务没用 校招都不看微服务的 还有就是后端行情是这样的 找实习纯看运气 秋招更是吃运气和缘分 如果对代码没有极致的追求 可以转测开
应届生简历当中,HR最关...
点赞 评论 收藏
分享
今天 00:55
门头沟学院
区域赛银,邀请赛金,打算十二月打下Java基础、背点八股、写个外卖后去投福建小厂的寒假实习,简历应该怎么写呢?以及福州/和厦门有推荐的小厂吗?
牛客53210502...:简历一页:把区域银,邀请赛金标粗,其他的奖除非凑一页否则没有必要写。或者多页:每个站一行这样都列出来。项目经历看看牛客其他人是怎么写的,写的不好呢。简历打磨好按部就班没问题的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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