117.填充每个节点的下一个右侧节点 II

​​题目来源:

leetcode题目,网址:117. 填充每个节点的下一个右侧节点指针 II - 力扣(LeetCode)

解题思路:

按层遍历时修改 next 指针即可,每一层除最后一个元素 的next 指针指向空外,皆指向同层下一个元素。

解题代码:

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

    Node() : val(0), left(NULL), right(NULL), next(NULL) {}

    Node(int _val) : val(_val), left(NULL), right(NULL), next(NULL) {}

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

class Solution {
public:
    Node* connect(Node* root) {
        if(root==nullptr){
            return nullptr;
        }
        queue<Node*> q1;
        q1.push(root);
        while(!q1.empty()){
            int size=q1.size();
            for(int i=0;i<size;i++){
                Node* temp=q1.front();
                q1.pop();
                if(i!=size-1){
                    temp->next=q1.front();
                }
                if(temp->left!=nullptr){
                    q1.push(temp->left);
                }
                if(temp->right!=nullptr){
                    q1.push(temp->right);
                }
            }
        }
        return root;
    }
};
复制代码

总结:

官方题解给出了两种解法。第一种是层次遍历。第二种是使用已建立的 next 指针,若在遍历 第 i 层的节点时,为第 i+1 层建立 next 指针,那么在遍历下一层时,只需知道下一层的首个节点即可通过已建立的 next 指针遍历整层。


相关推荐
2301_818419012 小时前
C++中的解释器模式变体
开发语言·c++·算法
爱学习的大牛1232 小时前
windows tcpview 类似功能 c++
c++
biter down3 小时前
C++11 统一列表初始化+std::initializer_list
开发语言·c++
ShineWinsu4 小时前
爬虫对抗:ZLibrary反爬机制实战分析技术文章大纲
c++
charlie1145141915 小时前
通用GUI编程技术——Win32 原生编程实战(十六)——Visual Studio 资源编辑器使用指南
开发语言·c++·ide·学习·gui·visual studio·win32
AlenTech5 小时前
141. 环形链表 - 力扣(LeetCode)
数据结构·leetcode·链表
DpHard5 小时前
现代 C++ 中 push 接口为何提供 const T& 与 T&& 两个重载
c++
U-52184F696 小时前
深度解析:从 Qt 的 Q_D 宏说起,C++ 工业级 SDK 是如何保证 ABI 稳定性的
数据库·c++·qt
dulu~dulu7 小时前
算法---寻找和为K的子数组
笔记·python·算法·leetcode
佑白雪乐7 小时前
<ACM进度212题>[2026-3-1,2026-3-26]
算法·leetcode