题目🦀
117. 填充每个节点的下一个右侧节点指针 II
难度中等
给定一个二叉树
struct Node { int val; Node *left; Node *right; Node *next; }
填充它的每个 next 指针,让这个指针指向其下一个右侧节点。如果找不到下一个右侧节点,则将 next 指针设置为 NULL
。
初始状态下,所有 next 指针都被设置为 NULL
。
进阶:
- 你只能使用常量级额外空间。
- 使用递归解题也符合要求,本题中递归程序占用的栈空间不算做额外的空间复杂度。
示例:
输入:root = [1,2,3,4,5,null,7] 输出:[1,#,2,3,#,4,5,7,#] 解释:给定二叉树如图 A 所示,你的函数应该填充它的每个 next 指针,以指向其下一个右侧节点,如图 B 所示。序列化输出按层序遍历顺序(由 next 指针连接),'#' 表示每层的末尾。
提示:
- 树中的节点数小于
6000
-100 <= node.val <= 100
解题思路🌵
- 此题同样采用层序遍历
- 在遍历每一层的时候将当前结点的next指向当前层的下一个结点
- 注意边界情况的处理
解题步骤🌟
- 此题采用层序遍历
- 处理边界条件
- 初始化
queue
- 遍历queue
- 遍历每一层的结点,如果当前len>1则还没到该层的最后一个结点
- 则当前结点的next指向queue[0]个结点
- 如果len<1则为当前层的最后一个结点,那么当前结点next指向null
源码🔥
/** * // Definition for a Node. * function Node(val, left, right, next) { * this.val = val === undefined ? null : val; * this.left = left === undefined ? null : left; * this.right = right === undefined ? null : right; * this.next = next === undefined ? null : next; * }; */ /** * @param {Node} root * @return {Node} */ var connect = function(root) { if(!root){ return root } const deque = [root] while(deque.length){ let len = deque.length while(len--){ const node = deque.shift() if(len>0){ node.next = deque[0] }else{ node.next = null } node.left && deque.push(node.left) node.right && deque.push(node.right) } } return root };
时间复杂度:O(N)
空间复杂度:O(1)
结束语🌞
那么鱼鱼的LeetCode算法篇的「leetCode」117-填充每个节点的下一个右侧节点指针||⚡️
就结束了,虽然前端对算法要求没有后端高,但是算法是编程基础,程序=数据结构➕算法
,所以算法这个东西没有捷径,只能多写多练,多总结,文章的目的其实很简单,就是督促自己去完成算法练习并总结和输出,菜不菜不重要,但是热爱🔥,喜欢大家能够喜欢我的短文,也希望通过文章认识更多志同道合的朋友,如果你也喜欢折腾
,欢迎加我好友
,一起沙雕
,一起进步
。