用栈实现队列
实现
思路
用两个栈实现。入队用输入栈stIn,出队用输出栈stOut。
实现pop()时,要注意pop只删除,不返回值。
复杂度分析
略
注意点
- stack的pop只能弹出,不返回值;弹出并获取值分成:用top()记录栈顶值、用pop()弹出(删除)栈顶值。
- class方法调用要用
->
。
代码实现
class MyQueue {
public:
stack<int> stIn;
stack<int> stOut;
MyQueue() {
}
void push(int x) {
stIn.push(x);
}
int pop() {
if(stOut.empty()){
while(!stIn.empty()){
stOut.push(stIn.top());
stIn.pop();
}
}
int result = stOut.top();
stOut.pop();
return result;
}
int peek() {
// 先pop弹出,记录一下,再push回去
int result = this->pop();
stOut.push(result);
return result;
}
bool empty() {
return stIn.empty() && stOut.empty();
}
};
/**
* Your MyQueue object will be instantiated and called as such:
* MyQueue* obj = new MyQueue();
* obj->push(x);
* int param_2 = obj->pop();
* int param_3 = obj->peek();
* bool param_4 = obj->empty();
*/
用队列实现栈
实现
思路
主要就pop的实现难想一点:循环size-1次把队首元素pop出来并入队到队尾,然后再取que.front()
就是栈顶元素了。
复杂度分析
略
注意点
略
代码实现
class MyStack {
public:
queue<int> que;
MyStack() {
}
void push(int x) {
que.push(x);
}
int pop() {
int loop = que.size() - 1;
while(loop--){
que.push(que.front());
que.pop();
}
int result = que.front();
que.pop();
return result;
}
int top() {
return que.back();
}
bool empty() {
return que.empty();
}
};
/**
* Your MyStack object will be instantiated and called as such:
* MyStack* obj = new MyStack();
* obj->push(x);
* int param_2 = obj->pop();
* int param_3 = obj->top();
* bool param_4 = obj->empty();
*/
标签:10,obj,队列,pop,60,int,que,push,empty
From: https://www.cnblogs.com/tazdingo/p/18005409