Appearance
每天一道Rust-LeetCode(2019-11-19)
坚持每天一道题,刷题学习Rust.
题目描述
使用栈实现队列的下列操作:
push(x) -- 将一个元素放入队列的尾部。 pop() -- 从队列首部移除元素。 peek() -- 返回队列首部的元素。 empty() -- 返回队列是否为空。 示例:
MyQueue queue = new MyQueue();
queue.push(1); queue.push(2); queue.peek(); // 返回 1 queue.pop(); // 返回 1 queue.empty(); // 返回 false 说明:
你只能使用标准的栈操作 -- 也就是只有 push to top, peek/pop from top, size, 和 is empty 操作是合法的。 你所使用的语言也许不支持栈。你可以使用 list 或者 deque(双端队列)来模拟一个栈,只要是标准的栈操作即可。 假设所有操作都是有效的 (例如,一个空的队列不会调用 pop 或者 peek 操作)。
来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/implement-queue-using-stacks 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解题思路
用Vector直接实现就行了 题目描述有问题,不知道哪些操作不让用
解题过程
rust
use std::collections::VecDeque;
struct MyQueue {
v: VecDeque<i32>,
}
/**
* `&self` means the method takes an immutable reference.
* If you need a mutable reference, change it to `&mut self` instead.
*/
impl MyQueue {
/** Initialize your data structure here. */
fn new() -> Self {
MyQueue { v: VecDeque::new() }
}
/** Push element x to the back of queue. */
fn push(&mut self, x: i32) {
self.v.push_back(x);
}
/** Removes the element from in front of queue and returns that element. */
fn pop(&mut self) -> i32 {
self.v.pop_front().expect("must have one")
}
/** Get the front element. */
fn peek(&self) -> i32 {
*self.v.front().expect("peek")
}
/** Returns whether the queue is empty. */
fn empty(&self) -> bool {
self.v.is_empty()
}
}
#[cfg(test)]
mod tests {
use super::*;
use crate::share::*;
#[test]
fn test() {
let mut q = MyQueue::new();
q.push(1);
q.push(2);
assert_eq!(q.peek(), 1);
assert_eq!(q.pop(), 1);
assert_eq!(q.empty(), false);
}
}
一点感悟
其他
欢迎关注我的github,本项目文章所有代码都可以找到.