1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53
use crate::*; pub struct Stack<T> { vec: Vec<T>, } impl<T> Stack<T> { pub fn new() -> Stack<T> { Stack { vec: vec![] } } pub fn push(&mut self, item: T) { self.vec.push(item); } pub fn extend<I: IntoIterator<Item = T>>(&mut self, items: I) { self.vec.extend(items); } pub fn pop(&mut self) -> Option<T> { self.vec.pop() } pub fn drop(&mut self, index: usize) { self.vec.remove(self.vec.len() - 1 - index); } pub fn at(&self, index: usize) -> Option<&T> { self.vec.get(self.vec.len() - 1 - index) } pub fn top(&self) -> Option<&T> { self.at(0) } pub fn size(&self) -> usize { self.vec.len() } pub fn iter(&self) -> std::iter::Rev<std::slice::Iter<T>> { self.vec.iter().rev() } } impl<T: fmt::Display> fmt::Debug for Stack<T> { fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { writeln!(f, "STACK ------------------------")?; for (i, o) in self.vec.iter().rev().enumerate() { writeln!(f, "{}: {}", i, o)?; } write!(f, "------------------------------") } }