algo/rust/24_binary_tree/insert_in_binary_tree.rs

20 lines
608 B
Rust
Raw Normal View History

// https://leetcode.com/problems/insert-into-a-binary-search-tree/
use super::util::tree::{TreeNode, to_tree};
pub fn insert_into_bst(root: Option<Rc<RefCell<TreeNode>>>, val: i32) -> Option<Rc<RefCell<TreeNode>>> {
insert(&root, val);
root
}
fn insert(node: &Option<Rc<RefCell<TreeNode>>>, val: i32) {
if let Some(n) = node {
let mut n = n.borrow_mut();
let target = if val > n.val { &mut n.right } else { &mut n.left };
if target.is_some() {
return insert(target, val);
}
*target = Some(Rc::new(RefCell::new(TreeNode::new(val))));
}
}