算法题 |
算法刷题专栏 | 面试必备算法 | 面试高频算法
越难的东西,越要努力坚持,因为它具有很高的价值,算法就是这样✨
作者简介:硕风和炜,CSDN-Java领域新星创作者,保研|国家奖学金|高中学习JAVA|大学完善JAVA开发技术栈|面试刷题|面经八股文|经验分享|好用的网站工具分享
恭喜你发现一枚宝藏博主,赶快收入囊中吧
人生如棋,我愿为卒,行动虽慢,可谁曾见我后退一步?
算法题 |
给定一个二叉树:
struct Node {
int val;
Node *left;
Node *right;
Node *next;
}
填充它的每个 next 指针,让这个指针指向其下一个右侧节点。如果找不到下一个右侧节点,则将 next 指针设置为 NULL 。
初始状态下,所有 next 指针都被设置为 NULL 。
提示:
树中的节点数在范围 [0, 6000] 内
-100 <= Node.val <= 100
进阶:
你只能使用常量级额外空间。
使用递归解题也符合要求,本题中递归程序的隐式栈空间不计入额外空间复杂度。
/*
// Definition for a Node.
class Node {
public int val;
public Node left;
public Node right;
public Node next;
public Node() {}
public Node(int _val) {
val = _val;
}
public Node(int _val, Node _left, Node _right, Node _next) {
val = _val;
left = _left;
right = _right;
next = _next;
}
};
*/
class Solution {
public List<Node> list = new ArrayList<>();
public Node connect(Node root) {
dfs(root,0);
return root;
}
public void dfs(Node node, int depth) {
if(node == null){
return;
}
if (depth == list.size()) {
list.add(node);
}else{
list.get(depth).next = node;
list.set(depth,node);
}
dfs(node.left,depth+1);
dfs(node.right,depth+1);
}
}
/*
// Definition for a Node.
class Node {
public int val;
public Node left;
public Node right;
public Node next;
public Node() {}
public Node(int _val) {
val = _val;
}
public 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==null) return root;
Queue<Node> queue=new LinkedList<>();
queue.add(root);
root.next=null;
while(!queue.isEmpty()){
int size=queue.size();
Node preLeft=null;
for(int i=0;i<size;i++){
Node n=queue.poll();
if(n.left!=null){
queue.add(n.left);
}
if(n.right!=null){
queue.add(n.right);
}
if(preLeft!=null){
preLeft.next=n;
}
preLeft=n;
}
}
return root;
}
}
最后,我想和大家分享一句一直激励我的座右铭,希望可以与大家共勉! |