文档链接:代码随想录
LeetCode232.用栈实现队列
题目链接:https://leetcode.cn/problems/implement-queue-using-stacks/
思路:主要考察用栈的基本操作来实现队列的先进先出,因为栈是先进后出的,所以一个栈肯定不行,此时我们就需要两个栈,一个输入栈,一个输出栈。
代码:
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() {
if(stackOut.empty() && stackIn.empty()) {
return true;
}else {
return false;
}
}
};
LeetCode225.用队列实现栈
题目链接:. - 力扣(LeetCode)
思路:考察队列的基本操作。可以只用一个队列实现。
代码:
class MyStack {
public:
queue<int> que;
MyStack() {
}
void push(int x) {
que.push(x);
}
int pop() {
int size = que.size();
size--;
while(size--) {
que.push(que.front());
que.pop();
}
int result = que.front();
que.pop();
return result;
}
int top() {
return que.back();
}
bool empty() {
return que.empty();
}
};
总结:这两天的任务还蛮轻松的,了解了队列和栈的基本操作。趁机恶补我的C++。加油加油!冲冲冲!