g0101_0200.s0101_symmetric_tree.Solution.rs Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of leetcode-in-all Show documentation
Show all versions of leetcode-in-all Show documentation
104 LeetCode algorithm problem solutions
The newest version!
// #Easy #Top_100_Liked_Questions #Top_Interview_Questions #Depth_First_Search #Breadth_First_Search
// #Tree #Binary_Tree #Data_Structure_I_Day_11_Tree #Level_2_Day_15_Tree
// #Big_O_Time_O(N)_Space_O(log(N)) #2024_09_08_Time_0_ms_(100.00%)_Space_2.2_MB_(78.98%)
// Definition for a binary tree node.
// #[derive(Debug, PartialEq, Eq)]
// pub struct TreeNode {
// pub val: i32,
// pub left: Option>>,
// pub right: Option>>,
// }
//
// impl TreeNode {
// #[inline]
// pub fn new(val: i32) -> Self {
// TreeNode {
// val,
// left: None,
// right: None
// }
// }
// }
use std::rc::Rc;
use std::cell::RefCell;
impl Solution {
pub fn is_symmetric(root: Option>>) -> bool {
fn compare(l: Option>>, r: Option>>) -> bool {
match (l, r) {
(None, None) => true,
(None, Some(n)) | (Some(n), None) => false,
(Some(l), Some(r)) => {
if l.borrow().val != r.borrow().val {
return false;
}
return compare(l.borrow().left.clone(), r.borrow().right.clone())
&& compare(l.borrow().right.clone(), r.borrow().left.clone())
}
}
}
match root {
Some(r) => compare(r.borrow().left.clone(), r.borrow().right.clone()),
None => true
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy