Files
Yudong Jin 772183705e Add ru version (#1865)
* Add Russian docs site baseline

* Add Russian localized codebase

* Polish Russian code wording

* Update ru code translation.

* Update code translation and chapter covers.

* Fix pythontutor extraction.

* Add README and landing page.

* placeholder of profiles

* Use figures of English version

* Remove chapter paperbook
2026-03-28 04:24:07 +08:00

72 lines
2.8 KiB
Rust
Raw Permalink Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
/*
* File: heap.rs
* Created Time: 2023-07-16
* Author: night-cruise (2586447362@qq.com)
*/
use hello_algo_rust::include::print_util;
use std::{cmp::Reverse, collections::BinaryHeap};
fn test_push_max(heap: &mut BinaryHeap<i32>, val: i32) {
heap.push(val); // Добавление элемента в кучу
println!("\nПосле добавления элемента {} в кучу", val);
print_util::print_heap(heap.iter().map(|&val| val).collect());
}
fn test_pop_max(heap: &mut BinaryHeap<i32>) {
let val = heap.pop().unwrap();
println!("\nПосле извлечения элемента вершины кучи {}", val);
print_util::print_heap(heap.iter().map(|&val| val).collect());
}
/* Driver Code */
fn main() {
/* Инициализация кучи */
// Инициализация минимальной кучи
#[allow(unused_assignments)]
let mut min_heap = BinaryHeap::new();
// BinaryHeap в Rust является максимальной кучей; для минимальной кучи обычно используют оболочку Reverse
// Инициализировать максимальную кучу
let mut max_heap = BinaryHeap::new();
println!("\nНиже приведен тестовый пример для max-heap");
/* Добавление элемента в кучу */
test_push_max(&mut max_heap, 1);
test_push_max(&mut max_heap, 3);
test_push_max(&mut max_heap, 2);
test_push_max(&mut max_heap, 5);
test_push_max(&mut max_heap, 4);
/* Получение элемента с вершины кучи */
let peek = max_heap.peek().unwrap();
println!("\nЭлемент на вершине кучи = {}", peek);
/* Извлечение элемента с вершины кучи */
test_pop_max(&mut max_heap);
test_pop_max(&mut max_heap);
test_pop_max(&mut max_heap);
test_pop_max(&mut max_heap);
test_pop_max(&mut max_heap);
/* Получение размера кучи */
let size = max_heap.len();
println!("\nКоличество элементов в куче = {}", size);
/* Проверка, пуста ли куча */
let is_empty = max_heap.is_empty();
println!("\nПуста ли куча: {}", is_empty);
/* Построить кучу по входному списку */
// Временная сложность равна O(n), а не O(nlogn)
min_heap = BinaryHeap::from(
vec![1, 3, 2, 5, 4]
.into_iter()
.map(|val| Reverse(val))
.collect::<Vec<Reverse<i32>>>(),
);
println!("\nПосле построения min-heap из входного списка");
print_util::print_heap(min_heap.iter().map(|&val| val.0).collect());
}