LeetCode116:填充每个节点的下一个右侧节点指针

填充每个节点的下一个右侧节点指针

题目:
在这里插入图片描述

思路:

题目意思可以理解为每一层 从左到右连接起来!
如果使用前序遍历如:

Node connect(Node root) {
    if (root == null || root.left == null) {
        return root;
    }
    root.left.next = root.right;
    connect(root.left);
    connect(root.right);
    return root;
}

则只会连接同一个父节点下的左右子节点,而跨父节点的5、6节点就不能连接了!

二叉树的问题难点在于,如何把题目的要求细化成每个节点需要做的事情
树相关的题目,先搞清楚要当前root做什么?然后根据方法递归调用方法,让子节点做相同的事情。

那么,此题可以增加参数 !一个节点做不到,我们就给他安排两个节点,将每一层二叉树节点连接起来可以细化成: 将每两个相邻节点都连接起来即可:
递归三部曲:

  1. 参数为两个root,不需要返回值
  2. 终止条件即子节点为null
  3. 连接当前两个参数节点的下一层中相邻的节点,前序遍历和后序遍历都可以 !!!
class Solution {
    public Node connect(Node root) {
        //一个参数不行传俩
        if(root==null){
            return null;
        }    
        con(root.left,root.right);
        return root;

    }

    private void con(Node r1,Node r2){
        if(r1==null || r2==null){ //  注意题目是完美二叉树,但写成|| 保险一点
            return ;  // 递归出口  
        }
        // 前序遍历 !
        r1.next=r2;
        
        // 同一个父节点的左右子节点
        con(r1.left,r1.right);
        con(r2.left,r2.right);
        //  跨越父节点的两个子节点
        con(r1.right,r2.left);
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值