1. 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 res = this->pop();
stIn.push(res);
return res;
}
bool empty() {
return stIn.empty() && stOut.empty();
}
};
2. 225. 用队列实现栈

class MyStack {
public:
queue<int> que1;
queue<int> que2;
MyStack() {
}
void push(int x) {
que1.push(x);
}
int pop() {
int size = que1.size();
size--;
while(size--)
{
que2.push(que1.front()) ;
que1.pop();
}
int result = que1.front();
que1.pop();
que1 = que2;
while(!que2.empty())
{
que2.pop();
}
return result;
}
int top() {
return que1.back();
}
bool empty() {
return que1.empty();
}
};
3. 20.有效括号

class Solution {
public:
bool isValid(string s) {
if(s.size() % 2 != 0) return false;
stack<char> st;
for(int i = 0;i < s.size(); i++)
{
if(s[i] == '(') st.push(')');
else if(s[i] == '[') st.push(']');
else if(s[i] == '{') st.push('}');
else if(st.empty() || st.top() != s[i]) return false;
else
st.pop();
}
return st.empty();
}
};
4. #1047. 删除字符串中的所有相邻重复项

class Solution {
public:
string removeDuplicates(string s) {
stack<char> st;
for(char i: s)
{
if(st.empty() || i != st.top())
{
st.push(i);
}
else
{
st.pop();
}
}
string res = "";
while(!st.empty())
{
res += st.top();
st.pop();
}
reverse(res.begin(), res.end());
return res;
}
};