12月29日代码随想录填充每个节点的下一个右侧节点指针

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

给定一个 完美二叉树,其所有叶子节点都在同一层,每个父节点都有两个子节点。二叉树定义如下:

复制代码
struct Node {
  int val;
  Node *left;
  Node *right;
  Node *next;
}

填充它的每个 next 指针,让这个指针指向其下一个右侧节点。如果找不到下一个右侧节点,则将 next 指针设置为 NULL

初始状态下,所有 next 指针都被设置为 NULL

示例 1:

复制代码
输入:root = [1,2,3,4,5,6,7]
输出:[1,#,2,3,#,4,5,6,7,#]
解释:给定二叉树如图 A 所示,你的函数应该填充它的每个 next 指针,以指向其下一个右侧节点,如图 B 所示。序列化的输出按层序遍历排列,同一层节点由 next 指针连接,'#' 标志着每一层的结束。

示例 2:

复制代码
输入:root = []
输出:[]

提示:

  • 树中节点的数量在 [0, 212 - 1] 范围内
  • -1000 <= node.val <= 1000

思路

在层序遍历的过程中写入节点的next指针,每一层定义一个temp元素用于放置上一个元素,方便在遍历到下一个值时放入前一节点的next指针。

java 复制代码
class Solution {
    public Node connect(Node root) {
        if(root==null){
            return root;
        }
        root.next=null;
        Deque<Node> stack=new ArrayDeque<>();
        stack.addFirst(root);
        while(!stack.isEmpty()){
            int len= stack.size();
            Node temp=null;
            for(int i=0;i<len;i++){
                Node node=stack.getFirst();
                if(node.left!=null){
                    stack.addLast(node.left);
                    stack.addLast(node.right);
                    if(temp!=null){
                        temp.next=node.left;
                        temp=node.left;
                    }else {
                        temp=node.left;
                    }
                    temp.next=node.right;
                    temp=node.right;
                    if(i==len-1){
                        node.right.next=null;
                    }
                    
                }
                stack.pollFirst();                
            }
        }
        return root; 
    }
}
相关推荐
C雨后彩虹10 分钟前
ConcurrentHashMap 核心锁机制:CAS+Synchronized 的协同工作原理
java·数据结构·哈希算法·集合·hashmap
爱学大树锯13 分钟前
1361 · 文字并排
算法
Tisfy20 分钟前
LeetCode 2483.商店的最少代价:两次遍历 -> 一次遍历
算法·leetcode·题解·遍历
集芯微电科技有限公司25 分钟前
DC-DC|40V/10A大电流高效率升压恒压控制器
c语言·数据结构·单片机·嵌入式硬件·fpga开发
C雨后彩虹27 分钟前
HashMap的线程安全问题:原因分析与解决方案
java·数据结构·哈希算法·集合·hashmap
YGGP31 分钟前
【Golang】LeetCode 279. 完全平方数
算法·leetcode
im_AMBER37 分钟前
Leetcode 87 等价多米诺骨牌对的数量
数据结构·笔记·学习·算法·leetcode
月明长歌1 小时前
【码道初阶】Leetcode771 宝石与石头:Set 判成员 vs List 判成员(同题两种写法的差距)
java·数据结构·leetcode·list·哈希算法·散列表
import_random1 小时前
[算法]时间序列(介绍)
算法
wuk9981 小时前
MATLAB中求解和分析马蒂厄方程
人工智能·算法·matlab