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

广度优先搜索解法:

1.该题的解法主要在于给每层节点的下一个右侧节点来进行赋值,所以我们只要再没遍历到每层最后一个节点时都给之前弹出的节点赋上当前对列中队首的节点就解决了这题。

java 复制代码
/*
// Definition for a Node.
class Node {
    public int val;
    public Node left;
    public Node right;
    public Node next;

    public Node() {}
    
    public Node(int _val) {
        val = _val;
    }

    public Node(int _val, Node _left, Node _right, Node _next) {
        val = _val;
        left = _left;
        right = _right;
        next = _next;
    }
};
*/

class Solution {
    public Node connect(Node root) {
        //判断root为零的情况
        if(root==null){
            return root;
        }
        //声明一个队列
        Queue<Node> qu=new LinkedList<Node>();
        //把root的根节点加入队列中
        qu.offer(root);
        //循环进队列和出队列
        while(!qu.isEmpty()){
            //获取队列中的长度
            int size=qu.size();
            //一层一层的遍历每层节点
            for(int i=0;i<size;i++){
                //弹出节点
                Node j=qu.poll();
                //当弹出的节点不是该层的最后一位节点时就进行来连接下一个右侧节点
                if(i!=size-1){
                    j.next=qu.peek();
                }
                //进行弹出节点的下一层左节点的进队列操作
                if(j.left!=null){
                    qu.offer(j.left);
                }
                 //进行弹出节点的下一层右节点的进队列操作
                if(j.right!=null){
                    qu.offer(j.right);
                }
            }
        }
      return root;
    }
}
相关推荐
yuanmazhiwu1 分钟前
计算机毕业设计:Python智慧出行数据分析与模式识别系统 Django框架 可视化 数据分析 PyEcharts 交通 深度学习(建议收藏)✅
人工智能·python·算法·数据分析·django·flask·课程设计
沉鱼.446 分钟前
第十一届题目
算法
C雨后彩虹12 分钟前
箱子之字形摆放
java·数据结构·算法·华为·面试
小肝一下2 小时前
每日两道力扣,day5
数据结构·c++·算法·leetcode·职场和发展·hot100
jiang_changsheng2 小时前
亚马逊的2026年最新算法变革自然流量分发机制“文本匹配”到“多模态意图理解”的范式革命
大数据·算法·推荐算法
OOJO7 小时前
c++---list介绍
c语言·开发语言·数据结构·c++·算法·list
别或许8 小时前
1、高数----函数极限与连续(知识总结)
算法
派大星~课堂9 小时前
【力扣-142. 环形链表2 ✨】Python笔记
python·leetcode·链表
田梓燊9 小时前
code 560
数据结构·算法·哈希算法
笨笨饿9 小时前
29_Z变换在工程中的实际意义
c语言·开发语言·人工智能·单片机·mcu·算法·机器人