58、二叉树的下一个节点

博客围绕二叉树展开,给定一个含指向父结点指针的二叉树及其中一个结点,要找出中序遍历顺序的下一个结点。给出两种思路,一是若节点右孩子存在,从右孩子出发沿左子结点指针找叶子节点;二是若节点非根节点,是父节点左孩子则返回父节点,否则向上遍历。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。

思路:若节点右孩子存在,则设置一个指针从该节点的右孩子出发,一直沿着指向左子结点的指针找到的叶子
节点即为下一个节点;若节点不是根节点。如果该节点是其父节点的左孩子,则返回父节点;否则继续向上遍
历其父节点的父节点,重复之前的判断,返回结果
 

public class Solution {
    public TreeLinkNode GetNext(TreeLinkNode node)
    {
       if(node==null)
           return null;
        if(node.right != null)//如果有右子树,则找右子树的最左节点
        {
            node = node.right;
            while(node.left != null)
                node = node.left;
            return node;
           
        }
        
        while(node.next!=null)//没右子树,则找第一个当前节点是父节点左孩子的节点
        {
           if (node.next.left==node)
               return node.next;
            node=node.next;
        }

        return null;   //退到了根节点仍没找到,则返回null
        
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值