数据结构与算法 - 二叉树的后继节点查找

  • 题目描述:给一个二叉树的随机节点,查找这个节点的后继节点
    • 前驱节点:对一棵二叉树进行中序遍历,遍历后的顺序,当前节点的前一个节点为该节点的前驱节点;
    • 后继节点:对一棵二叉树进行中序遍历,遍历后的顺序,当前节点的后一个节点为该节点的后继节点;
思路一:直接遍历全部的二叉树,根据顺序直接得出结果,但是时间复杂度是O(N)
思路二:首先判断这个节点是否有右子树,有的话直接找到这个右子树的最左的节点就是我们的后继节点,如果没有右子树,那么,我们判断当前节点的父节点的左节点是不是当前节点,是的话直接返回父节点,不是的话继续向上寻找,引用之间再次传递。
  • 节点定义
public static class Node{
   
        public int value;
        public Node parent;
        public Node left;
        public Node right;
        public Node(int value){
   
            this.value = value;
        }
    }
  • 函数主体
public static Node getSuccessorNode(Node node){
   
        if(node == null){
   
            return null;
        }
        //1.如果该节点有右子树的话,就找右子树的最左的节点
        if(node.right != null){
   
            return getRightNode(node.right);
        }
        //2.没有右子树的话,那么直接向上找每个节点的父节点的左节点是当前节点
        Node parent = node.parent;
        while (parent != null && node != parent.left){
   
            node = parent;
            parent = node.parent;
        }
        return parent
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值