剑指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;
    }
}
全部评论

相关推荐

01-30 09:45
燕山大学 Java
喵_coding:这种直接跑就完事了 哪有毕业了才签合同 任何offer和三方都没有的
点赞 评论 收藏
分享
2025-12-28 16:32
重庆邮电大学 Java
程序员花海:1.技能放最后,来面试默认你都会,技能没啥用 2.实习写的看起来没啥含金量,多读读部门文档,包装下 接LLM这个没含金量 也不要用重构这种 不会给实习生做的 3.抽奖这个还是Demo项目,实际在公司里面要考虑策略,满减,触发点,触发规则 库存 之类的,不是这个项目这么简单 4.教育背景提前,格式为 教育背景 实习 项目 技能 自我评价
简历被挂麻了,求建议
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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