Skip to content

Commit 56ee73e

Browse files
authored
Merge pull request neetcode-gh#924 from MaratKhakim/572-Subtree-Another
Kotlin: 572. Subtree of Another Tree
2 parents c8d56ee + 339f902 commit 56ee73e

File tree

1 file changed

+31
-0
lines changed

1 file changed

+31
-0
lines changed
Lines changed: 31 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,31 @@
1+
/**
2+
* Example:
3+
* var ti = TreeNode(5)
4+
* var v = ti.`val`
5+
* Definition for a binary tree node.
6+
* class TreeNode(var `val`: Int) {
7+
* var left: TreeNode? = null
8+
* var right: TreeNode? = null
9+
* }
10+
*/
11+
class Solution {
12+
fun isSubtree(s: TreeNode?, t: TreeNode?): Boolean {
13+
if (s == null)
14+
return false
15+
16+
return equals(s, t) || isSubtree(s.left, t) || isSubtree(s.right, t);
17+
}
18+
19+
fun equals(s: TreeNode?, t: TreeNode?): Boolean {
20+
if (s == null && t == null)
21+
return true;
22+
23+
if (s == null || t == null)
24+
return false;
25+
26+
if (s.`val` != t.`val`)
27+
return false;
28+
29+
return equals(s.left, t.left) && equals(s.right, t.right);
30+
}
31+
}

0 commit comments

Comments
 (0)