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

举报
兔老大 发表于 2021/04/23 00:10:36 2021/04/23
【摘要】 给定一个二叉树 struct Node {   int val;   Node *left;   Node *right;   Node *next; } 填充它的每个 next 指针,让这个指针指向其下一个右侧节点。如果找不到下一个右侧节点,则将 next 指针设置为 NULL。 初始状态下,所有 next 指针都被设置...

给定一个二叉树

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 所示。
 

提示:

树中的节点数小于 6000
-100 <= node.val <= 100

思路:层序遍历改一下,把同一层的连一下即可。


  
  1. /*
  2. // Definition for a Node.
  3. class Node {
  4. public int val;
  5. public Node left;
  6. public Node right;
  7. public Node next;
  8. public Node() {}
  9. public Node(int _val) {
  10. val = _val;
  11. }
  12. public Node(int _val, Node _left, Node _right, Node _next) {
  13. val = _val;
  14. left = _left;
  15. right = _right;
  16. next = _next;
  17. }
  18. };
  19. */
  20. class Solution {
  21. public Node connect(Node root) {
  22. if (root == null) {
  23. return null;
  24. }
  25. Queue<Node> Q = new LinkedList<Node>();
  26. Q.add(root);
  27. while (Q.size() > 0) {
  28. int size = Q.size();
  29. for(int i = 0; i < size; i++) {
  30. Node node = Q.poll();
  31. if (i < size - 1) {
  32. node.next = Q.peek();
  33. }
  34. if (node.left != null) {
  35. Q.add(node.left);
  36. }
  37. if (node.right != null) {
  38. Q.add(node.right);
  39. }
  40. }
  41. }
  42. return root;
  43. }
  44. }

 

文章来源: fantianzuo.blog.csdn.net,作者:兔老大RabbitMQ,版权归原作者所有,如需转载,请联系作者。

原文链接:fantianzuo.blog.csdn.net/article/details/104371790

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。