leet-code/src/main/java/leetcode/editor/cn/PopulatingNextRightPointersInEachNode.java

86 lines
2.3 KiB
Java
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

//给定一个 完美二叉树 ,其所有叶子节点都在同一层,每个父节点都有两个子节点。二叉树定义如下:
//
//
//struct Node {
// int val;
// Node *left;
// Node *right;
// Node *next;
//}
//
// 填充它的每个 next 指针,让这个指针指向其下一个右侧节点。如果找不到下一个右侧节点,则将 next 指针设置为 NULL。
//
// 初始状态下,所有 next 指针都被设置为 NULL。
//
//
//
// 进阶:
//
//
// 你只能使用常量级额外空间。
// 使用递归解题也符合要求,本题中递归程序占用的栈空间不算做额外的空间复杂度。
//
//
//
//
// 示例:
//
//
//
//
//输入root = [1,2,3,4,5,6,7]
//输出:[1,#,2,3,#,4,5,6,7,#]
//解释:给定二叉树如图 A 所示,你的函数应该填充它的每个 next 指针,以指向其下一个右侧节点,如图 B 所示。序列化的输出按层序遍历排列,同一层节点由
//next 指针连接,'#' 标志着每一层的结束。
//
//
//
//
// 提示:
//
//
// 树中节点的数量少于 4096
// -1000 <= node.val <= 1000
//
// Related Topics 树 深度优先搜索 广度优先搜索 二叉树
// 👍 494 👎 0
package leetcode.editor.cn;
import com.code.leet.entiy.Node;
//116:填充每个节点的下一个右侧节点指针
public class PopulatingNextRightPointersInEachNode {
public static void main(String[] args) {
//测试代码
Solution solution = new PopulatingNextRightPointersInEachNode().new Solution();
}
//力扣代码
//leetcode submit region begin(Prohibit modification and deletion)
class Solution {
public Node connect(Node root) {
if (root == null) {
return root;
}
Node cur = root;
while (cur != null) {
Node dummy = new Node(0);
Node pre = dummy;
while (cur != null && cur.left != null) {
pre.next = cur.left;
pre = pre.next;
pre.next = cur.right;
pre = pre.next;
cur = cur.next;
}
cur = dummy.next;
}
return root;
}
}
//leetcode submit region end(Prohibit modification and deletion)
}