-
Notifications
You must be signed in to change notification settings - Fork 2.4k
/
Copy path0572-subtree-of-another-tree.rs
32 lines (31 loc) · 1.16 KB
/
0572-subtree-of-another-tree.rs
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
use std::rc::Rc;
use std::cell::RefCell;
impl Solution {
pub fn is_subtree(
root: Option<Rc<RefCell<TreeNode>>>,
sub_root: Option<Rc<RefCell<TreeNode>>>
) -> bool {
fn is_sametree(a: Option<Rc<RefCell<TreeNode>>>, b: Option<Rc<RefCell<TreeNode>>>) -> bool {
match (a, b) {
(None, None) => true,
(Some(a), Some(b)) => {
a.borrow().val == b.borrow().val
&& is_sametree(a.borrow().left.clone(), b.borrow().left.clone())
&& is_sametree(a.borrow().right.clone(), b.borrow().right.clone())
}
_ => false,
}
}
match (root, sub_root) {
(_, None) => true,
(None, _) => false,
(Some(root), Some(sub_root)) => {
if is_sametree(Some(root.clone()), Some(sub_root.clone())) {
return true;
}
Solution::is_subtree(root.borrow().left.clone(), Some(sub_root.clone()))
|| Solution::is_subtree(root.borrow().right.clone(), Some(sub_root))
}
}
}
}