zoukankan      html  css  js  c++  java
  • LeetCode 116. Populating Next Right Pointers in Each Node

    原题链接在这里:https://leetcode.com/problems/populating-next-right-pointers-in-each-node/

    题目:

    You are given a perfect binary tree where all leaves are on the same level, and every parent has two children. The binary tree has the following definition:

    struct Node {
      int val;
      Node *left;
      Node *right;
      Node *next;
    }
    

    Populate each next pointer to point to its next right node. If there is no next right node, the next pointer should be set to NULL.

    Initially, all next pointers are set to NULL.

    Example:

    Input: {"$id":"1","left":{"$id":"2","left":{"$id":"3","left":null,"next":null,"right":null,"val":4},"next":null,"right":{"$id":"4","left":null,"next":null,"right":null,"val":5},"val":2},"next":null,"right":{"$id":"5","left":{"$id":"6","left":null,"next":null,"right":null,"val":6},"next":null,"right":{"$id":"7","left":null,"next":null,"right":null,"val":7},"val":3},"val":1}
    
    Output: {"$id":"1","left":{"$id":"2","left":{"$id":"3","left":null,"next":{"$id":"4","left":null,"next":{"$id":"5","left":null,"next":{"$id":"6","left":null,"next":null,"right":null,"val":7},"right":null,"val":6},"right":null,"val":5},"right":null,"val":4},"next":{"$id":"7","left":{"$ref":"5"},"next":null,"right":{"$ref":"6"},"val":3},"right":{"$ref":"4"},"val":2},"next":null,"right":{"$ref":"7"},"val":1}
    
    Explanation: Given the above perfect binary tree (Figure A), your function should populate each next pointer to point to its next right node, just like in Figure B.
    

    题解:

    递归调用,如果root.next不为null, root.right.next 等于 root.next.left, 然后root.left.next指向root.right.

    Time Complexity: O(n), 每个点访问不超过两遍. Space: O(logn).

    AC Java:

     1 /**
     2  * Definition for binary tree with next pointer.
     3  * public class TreeLinkNode {
     4  *     int val;
     5  *     TreeLinkNode left, right, next;
     6  *     TreeLinkNode(int x) { val = x; }
     7  * }
     8  */
     9 public class Solution {
    10     public void connect(TreeLinkNode root) {
    11         if(root == null){
    12             return;
    13         }
    14         if(root.right != null && root.next != null){
    15             root.right.next = root.next.left;
    16         } 
    17         if(root.left!=null){
    18             root.left.next = root.right;
    19         }
    20         connect(root.right);
    21         connect(root.left);
    22     }
    23 }

    Iteration版本

    Time Complexity: O(n). Space: O(1).

    AC Java:

     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 
     9     public Node() {}
    10 
    11     public Node(int _val,Node _left,Node _right,Node _next) {
    12         val = _val;
    13         left = _left;
    14         right = _right;
    15         next = _next;
    16     }
    17 };
    18 */
    19 class Solution {
    20     public Node connect(Node root) {
    21         Node cur = root;
    22         while(cur != null){
    23             Node dummyHead = new Node(); //记录下一层的假头
    24             Node it = dummyHead;
    25             
    26             while(cur != null){
    27                 if(cur.left != null){
    28                     it.next = cur.left;
    29                     it = it.next;
    30                 }
    31                 
    32                 if(cur.right != null){
    33                     it.next = cur.right;
    34                     it = it.next;
    35                 }
    36                 
    37                 cur = cur.next;  //cur 更新到下一层假头的next上面
    38             }
    39             
    40             cur = dummyHead.next;
    41         }
    42         
    43         return root;
    44     }
    45 }

    跟上Populating Next Right Pointers in Each Node IIBinary Tree Right Side View.

  • 相关阅读:
    知识图谱系列---机器学习---PIL图片处理
    知识图谱系列---知识图谱概论(摘录)
    Java系列整理---Python Java Scala 区别
    Java系列整理---Intellij IDEA 封装Jar包(提示错误: 找不到或无法加载主类)
    数据库系列整理---数据库访问优化法则
    hadoop系列整理---Spark基础架构(摘录)
    知识图谱系列---自然语言处理---Word2Vec超详细的原理推导(摘录)
    知识图谱系列---自然语言处理---词向量模型(word2vec) 详解
    知识积累---性能优化与框架搭建
    知识积累---Linux内核的整体架构
  • 原文地址:https://www.cnblogs.com/Dylan-Java-NYC/p/4824976.html
Copyright © 2011-2022 走看看