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

简介: 117. 填充每个节点的下一个右侧节点指针 II

给定一个二叉树

struct Node {
int val;
Node *left;
Node *right;
Node *next;
}

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

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

image.png

算法思想:用队列层次遍历树,首先把根节点放入队列,并且每次记录队列大小k,然后将k个元素依次出队,依次加入每个元素的左孩子、右孩子,再循环。这样保证每趟遍历的都是同一层的结点。

Node* connect(Node* root) {
        if(!root){
            return root;
        }
        queue<Node*> q;
        q.push(root);
        while(!q.empty()){
            int len=q.size();
            Node* pre=q.front();
            for(int i=0;i<len;i++){
                Node* p=q.front();
                if(p->left){
                    q.push(p->left);
                }
                if(p->right){
                    q.push(p->right);
                }
                q.pop();
                if(i!=0){
                    pre->next=p;
                    pre=p;
                }
            }
        }
        return root;
    }
相关文章
|
2月前
|
存储 SQL 算法
LeetCode 题目 117:填充每个节点的下一个右侧节点指针 II
LeetCode 题目 117:填充每个节点的下一个右侧节点指针 II
|
2月前
|
存储 SQL 算法
LeetCode 题目 116:填充每个节点的下一个右侧节点指针
LeetCode 题目 116:填充每个节点的下一个右侧节点指针
|
3月前
|
存储 C语言
链表—初始化指针变和创建新的节点------区别应用分析
链表—初始化指针变和创建新的节点------区别应用分析
|
3月前
|
Rust 索引
Rust 编程小技巧摘选(6)
Rust 编程小技巧摘选(6)
62 1
Rust 编程小技巧摘选(6)
力扣117 填充每个节点的下一个右侧节点指针II
力扣117 填充每个节点的下一个右侧节点指针II
|
3月前
|
Go Python Java
Python每日一练(20230404) Pow(x, n)、括号生成、填充每个节点的下一个右侧节点指针 II
Python每日一练(20230404) Pow(x, n)、括号生成、填充每个节点的下一个右侧节点指针 II
26 0
Python每日一练(20230404) Pow(x, n)、括号生成、填充每个节点的下一个右侧节点指针 II
|
2月前
|
C语言
指针进阶(C语言终)
指针进阶(C语言终)
|
5天前
|
C语言
【C初阶——指针5】鹏哥C语言系列文章,基本语法知识全面讲解——指针(5)
【C初阶——指针5】鹏哥C语言系列文章,基本语法知识全面讲解——指针(5)
|
5天前
|
C语言
【C初阶——指针4】鹏哥C语言系列文章,基本语法知识全面讲解——指针(4)
【C初阶——指针4】鹏哥C语言系列文章,基本语法知识全面讲解——指针(4)
|
5天前
|
存储 编译器 C语言
【C初阶——指针3】鹏哥C语言系列文章,基本语法知识全面讲解——指针(3)
【C初阶——指针3】鹏哥C语言系列文章,基本语法知识全面讲解——指针(3)