-
Notifications
You must be signed in to change notification settings - Fork 2.4k
/
Copy path0572-subtree-of-another-tree.js
96 lines (68 loc) · 2.22 KB
/
0572-subtree-of-another-tree.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
/**
* https://leetcode.com/problems/subtree-of-another-tree/
* @param {TreeNode} root
* @param {TreeNode} subRoot
* @return {boolean}
*/
var isSubtree = function(root, subRoot) {
if (!root) return false
if (isSame(root, subRoot)) return true
const hasLeftTree = isSubtree(root.left, subRoot)
const hasRightTree = isSubtree(root.right, subRoot)
return hasLeftTree || hasRightTree
};
const isSame = (root, subRoot) => {
const hasReachedEnd = !(root && subRoot)
if (hasReachedEnd) return root === subRoot
const isMismatch = root.val !== subRoot.val
if (isMismatch) return false
const isLeftSame = isSame(root.left, subRoot.left)
const isRightSame = isSame(root.right, subRoot.right)
return isLeftSame && isRightSame
}
const hash = (val) => require('crypto')
.createHash('md5')
.update(val)
.digest('hex')
const merkle = (root) => {
if (!root) return '#'
const { left, val, right } = root
const leftMerkle = merkle(left)
const rightMerkle = merkle(right)
const merkleVal = [ leftMerkle, val, rightMerkle ].join('')
const merkleHash = hash(merkleVal)
root.merkle = merkleHash
return root.merkle
}
const search = (root, subRoot) => {
if (!root) return false
const hasSamePath = root.merkle === subRoot.merkle
if (hasSamePath) return true
const left = search(root.left, subRoot)
const right = search(root.right, subRoot)
return left || right
}
var isSubtree = function(root, subRoot) {
[ root, subRoot ].forEach(merkle)
return search(root, subRoot)
}
const hashify = (root, hash, postOrderKey) => {
if (!root) return '#'
const left = hashify(root.left, hash, postOrderKey)
const right = hashify(root.right, hash, postOrderKey)
const key = [left, root.val, right].join('')
if (!hash.has(key)) {
hash.set(key, postOrderKey[0])
postOrderKey[0]++
}
return hash.get(key)
}
var isSubtree = function(root, subRoot, hash = new Map (), postOrderKey = [0]) {
hashify(root, hash, postOrderKey)
const hashKey = [
hashify(subRoot.left, hash, postOrderKey),
subRoot.val,
hashify(subRoot.right, hash, postOrderKey)
].join('')
return hash.has(hashKey)
}