题目部分
232.用栈实现队列
之前看过一遍所以挺快做的
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() {
int result = this->pop();
stout.push(result);
return result;
}
bool empty() {
return stin.empty()&&stout.empty();
}
};
225.用队列实现栈
没必要用两个队列,直接添加回自己的队列就行,用一个队列
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();
}
};