zoukankan      html  css  js  c++  java
  • [Swift]LeetCode572. 另一个树的子树 | Subtree of Another Tree

    ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
    ➤微信公众号:山青咏芝(shanqingyongzhi)
    ➤博客园地址:山青咏芝(https://www.cnblogs.com/strengthen/
    ➤GitHub地址:https://github.com/strengthen/LeetCode
    ➤原文地址:https://www.cnblogs.com/strengthen/p/9852026.html 
    ➤如果链接不是山青咏芝的博客园地址,则可能是爬取作者的文章。
    ➤原文已修改更新!强烈建议点击原文地址阅读!支持作者!支持原创!
    ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★

    Given two non-empty binary trees s and t, check whether tree t has exactly the same structure and node values with a subtree of s. A subtree of s is a tree consists of a node in s and all of this node's descendants. The tree s could also be considered as a subtree of itself.

    Example 1:
    Given tree s:

         3
        / 
       4   5
      / 
     1   2
    

    Given tree t:

       4 
      / 
     1   2
    

    Return true, because t has the same structure and node values with a subtree of s.

     Example 2:

    Given tree s:

         3
        / 
       4   5
      / 
     1   2
        /
       0
    

    Given tree t:

       4
      / 
     1   2
    

    Return false.


     给定两个非空二叉树 s 和 t,检验 s 中是否包含和 t 具有相同结构和节点值的子树。s 的一个子树包括 s 的一个节点和这个节点的所有子孙。s 也可以看做它自身的一棵子树。

    示例 1:
    给定的树 s:

         3
        / 
       4   5
      / 
     1   2
    

    给定的树 t:

       4 
      / 
     1   2
    

    返回 true,因为 t 与 s 的一个子树拥有相同的结构和节点值。

    示例 2:
    给定的树 s:

         3
        / 
       4   5
      / 
     1   2
        /
       0
    

    给定的树 t:

       4
      / 
     1   2
    

    返回 false。


    376ms

     1 /**
     2  * Definition for a binary tree node.
     3  * public class TreeNode {
     4  *     public var val: Int
     5  *     public var left: TreeNode?
     6  *     public var right: TreeNode?
     7  *     public init(_ val: Int) {
     8  *         self.val = val
     9  *         self.left = nil
    10  *         self.right = nil
    11  *     }
    12  * }
    13  */
    14 class Solution {
    15     func isSubtree(_ s: TreeNode?, _ t: TreeNode?) -> Bool {
    16         if s == nil || t == nil {return false}
    17         return isSameTree(s,t) || isSubtree(s?.left,t) || isSubtree(s?.right,t)
    18     }
    19     func isSameTree(_ p: TreeNode?, _ q: TreeNode?) -> Bool
    20     {
    21         if p == nil
    22         {
    23             if q == nil
    24             {
    25                 return true
    26             }
    27             return false
    28         }
    29         else if q == nil
    30         {
    31             return false
    32         }
    33         return p?.val == q?.val 
    34         && isSameTree(p?.left, q?.left) 
    35         && isSameTree(p?.right, q?.right)
    36     }
    37     
    38 }

    120ms

     1 /**
     2  * Definition for a binary tree node.
     3  * public class TreeNode {
     4  *     public var val: Int
     5  *     public var left: TreeNode?
     6  *     public var right: TreeNode?
     7  *     public init(_ val: Int) {
     8  *         self.val = val
     9  *         self.left = nil
    10  *         self.right = nil
    11  *     }
    12  * }
    13  */
    14 class Solution {
    15 func isSameTree(_ s: TreeNode?, _ t: TreeNode?) -> Bool {
    16     if (s == nil && t != nil) || (s != nil && t == nil) {
    17         return false
    18     }
    19     
    20     if s == nil && t == nil {
    21         return true
    22     }
    23     
    24     if s!.val != t!.val {
    25         return false
    26     }
    27     
    28     return isSubtree(s?.left, t?.left) && isSubtree(s?.right, t?.right)
    29 }
    30 
    31 func getSuitableNode(_ s: TreeNode?, _ dest: Int, _ result: inout [TreeNode?]) -> Int {
    32     guard let s = s else {
    33         return -1
    34     }
    35     
    36     let depth = max(getSuitableNode(s.left, dest, &result), getSuitableNode(s.right, dest, &result)) + 1
    37     if depth == dest {
    38         result.append(s)
    39     }
    40     
    41     return depth
    42 }
    43 
    44 func isSubtree(_ s: TreeNode?, _ t: TreeNode?) -> Bool {
    45     if s == nil && t == nil {
    46         return true
    47     }
    48     
    49     if s == nil || t == nil {
    50         return false
    51     }
    52     
    53     var nodes = [TreeNode?]()
    54     let depth = getSuitableNode(t, -1, &nodes)
    55     
    56     getSuitableNode(s, depth, &nodes)
    57     
    58     for node in nodes {
    59         if isSameTree(node, t) {
    60             return true
    61         }
    62     }
    63     
    64     return false
    65 }
    66 }

    124ms

     1 /**
     2  * Definition for a binary tree node.
     3  * public class TreeNode {
     4  *     public var val: Int
     5  *     public var left: TreeNode?
     6  *     public var right: TreeNode?
     7  *     public init(_ val: Int) {
     8  *         self.val = val
     9  *         self.left = nil
    10  *         self.right = nil
    11  *     }
    12  * }
    13  */
    14 class Solution {
    15     func isSubtree(_ s: TreeNode?, _ t: TreeNode?) -> Bool {
    16         let S = getString(s)
    17         let T = getString(t)
    18         
    19         return S.contains(T)
    20     }
    21     
    22     func getString(_ n: TreeNode?) -> String {
    23         guard let n = n else { return "nil" }
    24         
    25         return "#" + String(n.val) + getString(n.left) + getString(n.right)
    26     }
    27 }

    164ms

     1 class Solution {
     2     func isSubtree(_ s: TreeNode?, _ t: TreeNode?) -> Bool {
     3         guard let t = t else {
     4             return s == nil
     5         }
     6 
     7         if let s = s {
     8             if s.val == t.val {
     9                 return isSameTree(s,t) || isSubtree(s.left,t) || isSubtree(s.right,t)
    10             } else {
    11                 return isSubtree(s.left,t) || isSubtree(s.right,t)
    12             }
    13         }
    14         return false
    15     }
    16     
    17     func isSameTree(_ s:TreeNode?, _ t:TreeNode?) -> Bool {
    18         guard let _s = s, let _t = t else {
    19             return s == nil && t == nil
    20         }
    21         if _s.val != _t.val {
    22             return false
    23         }
    24         
    25         return isSameTree(_s.left,_t.left) && isSameTree(_s.right,_t.right)
    26     }
    27 }

    180ms

     1 /**
     2  * Definition for a binary tree node.
     3  * public class TreeNode {
     4  *     public var val: Int
     5  *     public var left: TreeNode?
     6  *     public var right: TreeNode?
     7  *     public init(_ val: Int) {
     8  *         self.val = val
     9  *         self.left = nil
    10  *         self.right = nil
    11  *     }
    12  * }
    13  */
    14 class Solution {
    15     func isSubtree(_ s: TreeNode?, _ t: TreeNode?) -> Bool {
    16         guard let s = s else {
    17             return t == nil
    18         }
    19         
    20         guard let t = t else {
    21             return true
    22         }
    23         
    24         let left = isSubtree(s.left, t)
    25         let right = isSubtree(s.right, t)
    26         return left || right || isSameTree(s, t)
    27     }
    28     
    29     fileprivate func isSameTree(_ s: TreeNode?, _ t: TreeNode?) -> Bool {
    30         
    31         guard let s = s else {
    32             return t == nil
    33         }
    34         
    35         guard let t = t else {
    36             return false
    37         }
    38         
    39         let left = isSameTree(s.left, t.left)
    40         let right = isSameTree(s.right, t.right)
    41         return s.val == t.val && left && right
    42     }
    43 }
  • 相关阅读:
    python 获取时间戳
    【转载】Git分支
    【转载】Jmeter分布式测试
    【总结】异常处理
    【转载】linux-查看日志
    【转载】python中if-else的多种写法
    【转载】Linux中rz和sz命令
    【转载】pip 使用国内源
    wrk(一)
    angular-gridster2使用
  • 原文地址:https://www.cnblogs.com/strengthen/p/9852026.html
Copyright © 2011-2022 走看看