/* * File: array_stack.rs * Created Time: 2023-02-05 * Author: WSL0809 (wslzzy@outlook.com), codingonion (coderonion@gmail.com) */ use hello_algo_rust::include::print_util; /* 配列ベースのスタック */ struct ArrayStack { stack: Vec, } impl ArrayStack { /* スタックを初期化 */ fn new() -> ArrayStack { ArrayStack:: { stack: Vec::::new(), } } /* スタックの長さを取得 */ fn size(&self) -> usize { self.stack.len() } /* スタックが空かどうかを判定 */ fn is_empty(&self) -> bool { self.size() == 0 } /* プッシュ */ fn push(&mut self, num: T) { self.stack.push(num); } /* ポップ */ fn pop(&mut self) -> Option { self.stack.pop() } /* スタックトップの要素にアクセス */ fn peek(&self) -> Option<&T> { if self.is_empty() { panic!("スタックが空です") }; self.stack.last() } /* &Vec を返す */ fn to_array(&self) -> &Vec { &self.stack } } /* Driver Code */ fn main() { // スタックを初期化 let mut stack = ArrayStack::::new(); // 要素をプッシュ stack.push(1); stack.push(3); stack.push(2); stack.push(5); stack.push(4); print!("スタック stack = "); print_util::print_array(stack.to_array()); // スタックトップの要素にアクセス let peek = stack.peek().unwrap(); print!("\nスタックトップ要素 peek = {}", peek); // 要素をポップ let pop = stack.pop().unwrap(); print!("\n取り出した要素 pop = {pop}、取り出し後 stack = "); print_util::print_array(stack.to_array()); // スタックの長さを取得 let size = stack.size(); print!("\nスタックの長さ size = {size}"); // 空かどうかを判定 let is_empty = stack.is_empty(); print!("\nスタックが空かどうか = {is_empty}"); }