/* * File: queue.rs * Created Time: 2023-02-05 * Author: codingonion (coderonion@gmail.com), xBLACKICEx (xBLACKICEx@outlook.com) */ include!("../include/include.rs"); use std::collections::VecDeque; /* Driver Code */ pub fn main() { // 初始化佇列 let mut queue: VecDeque = VecDeque::new(); // 元素入列 queue.push_back(1); queue.push_back(3); queue.push_back(2); queue.push_back(5); queue.push_back(4); print!("佇列 queue = "); print_util::print_queue(&queue); // 訪問佇列首元素 let peek = queue.front().unwrap(); println!("\n佇列首元素 peek = {peek}"); // 元素出列 let pop = queue.pop_front().unwrap(); print!("出列元素 pop = {pop},出列後 queue = "); print_util::print_queue(&queue); // 獲取佇列的長度 let size = queue.len(); print!("\n佇列長度 size = {size}"); // 判斷佇列是否為空 let is_empty = queue.is_empty(); print!("\n佇列是否為空 = {is_empty}"); }