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

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

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


46340b0ae36d4ebf90c97419a332f898.png

/*
// 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) {
        Node* result;
        Node*  node ; //迭代节点
        queue<Node* > my_que; //队列
        if(root == nullptr) return root;
        else // 根节点进队列
        {
            my_que.push(root);
        }
        while(my_que.empty() != 1)
        {
            int size = my_que.size(); 
            for(int i=0 ; i<size ; i++) 
            {
                node = my_que.front(); //该层级的点弹出放入数组
                my_que.pop();
                if(i<size-1)//如果该节点不是该层次的最后一个,next指针连接下一个
                {
                    node->next = my_que.front();
                }else//该节点是该层次的最后一个,next连接空
                {
                    node->next = nullptr;
                }
                //每一个弹出点的下一个层级左右节点压入队列
                if(node->left != nullptr)    my_que.push(node->left);
                if(node->right != nullptr)   my_que.push(node->right);
            }
        }
        return root;
    }
};

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

0c6e2521069341738994c8f9ea8ae762.png0035219f35674794a66a86a68852397b.png

和116区别是一个是完全二叉树,一个不是。代码完全一致

二刷

/*
// 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) {
        queue<Node*> my_que;  
        if( root == nullptr ) return root;
        else my_que.push(root);
        while(my_que.size() != 0)
        {
            int size = my_que.size();
            for(int i=0 ; i<size ;i++)
            {
                Node* tmp_node = my_que.front();
                my_que.pop();
                if(i == size-1) tmp_node->next = nullptr;
                else tmp_node->next = my_que.front();
                if(tmp_node->left != nullptr) my_que.push(tmp_node->left);
                if(tmp_node->right != nullptr) my_que.push(tmp_node->right);
            }
        }
        return root;
    }
};
相关文章
|
16天前
|
算法 容器
【算法】——双指针算法合集(力扣)
移动零,复写零,快乐数,盛最多水的容器,有效三角形的个数,和为s的两个数(查找总价格为目标值的两个商品 ),三数之和,四数之和
|
3月前
LeetCode第二十四题(两两交换链表中的节点)
这篇文章介绍了LeetCode第24题的解法,即如何通过使用三个指针(preNode, curNode, curNextNode)来两两交换链表中的节点,并提供了详细的代码实现。
32 0
LeetCode第二十四题(两两交换链表中的节点)
|
3月前
Leetcode第十九题(删除链表的倒数第N个节点)
LeetCode第19题要求删除链表的倒数第N个节点,可以通过快慢指针法在一次遍历中实现。
49 0
Leetcode第十九题(删除链表的倒数第N个节点)
|
3月前
【LeetCode 46】450.删除二叉搜索树的节点
【LeetCode 46】450.删除二叉搜索树的节点
24 0
|
5月前
|
算法
LeetCode第24题两两交换链表中的节点
这篇文章介绍了LeetCode第24题"两两交换链表中的节点"的解题方法,通过使用虚拟节点和前驱节点技巧,实现了链表中相邻节点的交换。
LeetCode第24题两两交换链表中的节点
|
5月前
|
Python
【Leetcode刷题Python】450. 删除二叉搜索树中的节点
LeetCode上538号问题"把二叉搜索树转换为累加树"的Python实现,使用反向中序遍历并记录节点值之和来更新每个节点的新值。
50 4
【Leetcode刷题Python】450. 删除二叉搜索树中的节点
10_填充每个节点的下一个右侧节点指针
10_填充每个节点的下一个右侧节点指针
|
5月前
|
Python
【Leetcode刷题Python】剑指 Offer 22. 链表中倒数第k个节点
Leetcode题目"剑指 Offer 22. 链表中倒数第k个节点"的Python解决方案,使用双指针法找到并返回链表中倒数第k个节点。
61 5
|
5月前
|
Python
【Leetcode刷题Python】222. 完全二叉树的节点个数
LeetCode第222题"完全二叉树的节点个数"的Python代码实现,通过递归和深度优先遍历的方法来计算给定完全二叉树的节点总数。
57 5
|
5月前
|
Python
【Leetcode刷题Python】剑指 Offer 18. 删除链表的节点
Leetcode题目"剑指 Offer 18. 删除链表的节点"的Python解决方案,通过使用双指针法找到并删除链表中值为特定数值的节点,然后返回更新后的链表头节点。
49 4