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; 
    }
}
相关推荐
呼啦啦啦啦啦啦啦啦2 小时前
常见的排序算法
java·算法·排序算法
胡萝卜3.03 小时前
数据结构初阶:排序算法(一)插入排序、选择排序
数据结构·笔记·学习·算法·排序算法·学习方法
地平线开发者3 小时前
LLM 中 token 简介与 bert 实操解读
算法·自动驾驶
lyx33136967593 小时前
Pandas数据结构详解Series与DataFrame
数据结构·pandas
scx201310044 小时前
20250814 最小生成树和重构树总结
c++·算法·最小生成树·重构树
阿巴~阿巴~4 小时前
冒泡排序算法
c语言·开发语言·算法·排序算法
散1124 小时前
01数据结构-交换排序
数据结构·算法
yzx9910135 小时前
Yolov模型的演变
人工智能·算法·yolo
weixin_307779135 小时前
VS Code配置MinGW64编译SQLite3库
开发语言·数据库·c++·vscode·算法
无聊的小坏坏5 小时前
拓扑排序详解:从力扣 207 题看有向图环检测
算法·leetcode·图论·拓扑学