理论基础
对于stack
来说,所有元素必须符合先进后出规则,所以栈不提供走访功能,不能遍历,不提供迭代器。stack
不是容器,是适配器。stack
缺省底层结构为deque
,deque
是双向队列,封住一端,即可实现栈的逻辑。
对于queue
来说,所有元素必须符合先进先出规则。queue
缺省底层结构也为deque
232.用栈实现队列
题目链接: 232.用栈实现队列
使用函数的复用
class MyQueue {
public:
stack<int> stackIn;
stack<int> stackOut;
MyQueue() {
}
void push(int x) {
stackIn.push(x);
}
int pop() {
if (stackOut.empty()) {
while (!stackIn.empty()) {
stackOut.push(stackIn.top());
stackIn.pop();
}
}
int result = stackOut.top();
stackOut.pop();
return result;
}
int peek() {
int result = this->pop();//函数的复用
stackOut.push(result);
return result;
}
bool empty() {
//return stackIn.empty() && stackOut.empty() ? true : false; //可以被简化为下面的
return stackIn.empty() && stackOut.empty();
}
};
225. 用队列实现栈
题目链接: 225. 用队列实现栈
队列实现栈,只用一个队列即可,因为队列是双开口的。
class MyStack {
public:
queue<int> que;
MyStack() {
}
void push(int x) {
que.push(x);
}
int pop() {
int cnt = que.size();
while (--cnt) {//先减1,判断while
que.push(que.front());//弹出元素放入队尾
que.pop();
}
int result = que.front();
que.pop();
return result;
}
int top() {
return que.back();//直接从队尾取出
}
bool empty() {
return que.empty();
}
};