zoukankan      html  css  js  c++  java
  • 1485. Clone Binary Tree With Random Pointer

    package LeetCode_1485
    
    /**
     * 1485. Clone Binary Tree With Random Pointer
     * (Prime)
     * A binary tree is given such that each node contains an additional random pointer which could point to any node in the tree or null.
    Return a deep copy of the tree.
    The tree is represented in the same input/output way as normal binary trees where each node is represented as a pair of [val, random_index] where:
    val: an integer representing Node.val
    random_index: the index of the node (in the input) where the random pointer points to, or null if it does not point to any node.
    You will be given the tree in class Node and you should return the cloned tree in class NodeCopy.
    NodeCopy class is just a clone of Node class with the same attributes and constructors.
     * */
    class Node(var `val`: Int) {
        var left: Node? = null
        var right: Node? = null
        var random: Node? = null
    }
    
    class Solution {
        /*
        * solution: DFS, Time complexity:O(n), Space complexity:O(n)
        * */
    
        val map = HashMap<Node, Node>()
    
        fun copyRandomBinaryTree(root: Node?): Node? {
            if (root == null) {
                return null
            }
            return copy(root)
        }
    
        private fun copy(root: Node?): Node? {
            if (root == null) {
                return null
            }
            if (map.containsKey(root)) {
                return map.get(root)
            }
            val copyNode = Node(root.`val`)
            map.put(root, copyNode)
            copyNode.left = copy(root.left)
            copyNode.right = copy(root.right)
            copyNode.random = copy(root.random)
            return copyNode
        }
    }
  • 相关阅读:
    APK自我保护方法
    Andorid APK反逆向解决方案---梆梆加固原理探寻
    判断android文件是否加壳
    java调用dll-JNA
    Java调用本地接口
    pat00-自测2. 素数对猜想 (20)
    pat00-自测4. Have Fun with Numbers (20)
    pat00-自测3. 数组元素循环右移问题 (20)
    pat00-自测1. 打印沙漏(20)
    pat1013. Battle Over Cities (25)
  • 原文地址:https://www.cnblogs.com/johnnyzhao/p/13290874.html
Copyright © 2011-2022 走看看