/* * File: array_binary_tree.rs * Created Time: 2023-07-25 * Author: night-cruise (2586447362@qq.com) */ use hello_algo_rust::include::{print_util, tree_node}; /* Класс двоичного дерева в массивном представлении */ struct ArrayBinaryTree { tree: Vec>, } impl ArrayBinaryTree { /* Конструктор */ fn new(arr: Vec>) -> Self { Self { tree: arr } } /* Вместимость списка */ fn size(&self) -> i32 { self.tree.len() as i32 } /* Получить значение узла с индексом i */ fn val(&self, i: i32) -> Option { // Если индекс выходит за границы, вернуть None, обозначающий пустую позицию if i < 0 || i >= self.size() { None } else { self.tree[i as usize] } } /* Получить индекс левого дочернего узла узла с индексом i */ fn left(&self, i: i32) -> i32 { 2 * i + 1 } /* Получить индекс правого дочернего узла узла с индексом i */ fn right(&self, i: i32) -> i32 { 2 * i + 2 } /* Получить индекс родительского узла узла с индексом i */ fn parent(&self, i: i32) -> i32 { (i - 1) / 2 } /* Обход в ширину */ fn level_order(&self) -> Vec { self.tree.iter().filter_map(|&x| x).collect() } /* Обход в глубину */ fn dfs(&self, i: i32, order: &'static str, res: &mut Vec) { if self.val(i).is_none() { return; } let val = self.val(i).unwrap(); // Предварительный обход if order == "pre" { res.push(val); } self.dfs(self.left(i), order, res); // Симметричный обход if order == "in" { res.push(val); } self.dfs(self.right(i), order, res); // Обратный обход if order == "post" { res.push(val); } } /* Предварительный обход */ fn pre_order(&self) -> Vec { let mut res = vec![]; self.dfs(0, "pre", &mut res); res } /* Симметричный обход */ fn in_order(&self) -> Vec { let mut res = vec![]; self.dfs(0, "in", &mut res); res } /* Обратный обход */ fn post_order(&self) -> Vec { let mut res = vec![]; self.dfs(0, "post", &mut res); res } } /* Driver Code */ fn main() { // Инициализировать двоичное дерево // Здесь используется функция, напрямую строящая двоичное дерево из массива let arr = vec![ Some(1), Some(2), Some(3), Some(4), None, Some(6), Some(7), Some(8), Some(9), None, None, Some(12), None, None, Some(15), ]; let root = tree_node::vec_to_tree(arr.clone()).unwrap(); println!("\nИнициализация двоичного дерева\n"); println!("Массивное представление двоичного дерева:"); println!( "[{}]", arr.iter() .map(|&val| if let Some(val) = val { format!("{val}") } else { "null".to_string() }) .collect::>() .join(", ") ); println!("Связное представление двоичного дерева:"); print_util::print_tree(&root); // Класс двоичного дерева в массивном представлении let abt = ArrayBinaryTree::new(arr); // Доступ к узлу let i = 1; let l = abt.left(i); let r = abt.right(i); let p = abt.parent(i); println!( "\nТекущий индекс узла = {}, значение = {}",\ni,\nif let Some(val) = abt.val(i) {\n format!("{val}")\n} else {\n "null".to_string()\n} ); println!( "Индекс левого дочернего узла = {}, значение = {}", l, if let Some(val) = abt.val(l) { format!("{val}") } else { "null".to_string() } ); println!( "Индекс правого дочернего узла = {}, значение = {}", r, if let Some(val) = abt.val(r) { format!("{val}") } else { "null".to_string() } ); println!( "Индекс родительского узла = {}, значение = {}", p, if let Some(val) = abt.val(p) { format!("{val}") } else { "null".to_string() } ); // Обходить дерево let mut res = abt.level_order(); println!("\nОбход в ширину: {:?}", res); res = abt.pre_order(); println!("Предварительный обход: {:?}", res); res = abt.in_order(); println!("Симметричный обход: {:?}", res); res = abt.post_order(); println!("Обратный обход: {:?}", res); }