代码随想录算法训练营DAY10第五章 栈与队列part01

目录

[232. 用栈实现队列](#232. 用栈实现队列)

[225. 用队列实现栈](#225. 用队列实现栈)

[20. 有效的括号](#20. 有效的括号)

[1047. 删除字符串中的所有相邻重复项](#1047. 删除字符串中的所有相邻重复项)


232. 用栈实现队列

cpp 复制代码
class MyQueue {
public:
    stack<int> in;
    stack<int> out;
    MyQueue() {
    }
    void push(int x) {
        in.push(x);
    }
    int pop() {
        if(out.empty()){
            while(!in.empty()){
                out.push(in.top());
                in.pop();
            }
        }
        int res=out.top();
        out.pop();
        return res;
    }
    int peek() {
        int res=this->pop();
        out.push(res);
        return res;
    }
    bool empty() {
        return in.empty()&&out.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();
 */

225. 用队列实现栈

cpp 复制代码
class MyStack {
public:
    queue<int> q1;
    queue<int> q2;
    MyStack() {
    }
    void push(int x) {
        q1.push(x);   
    }
    int pop() {
        int size=q1.size();
        size--;
        while(size--){
            q2.push(q1.front());
            q1.pop();
        }
        int res=q1.front();
        q1.pop();
        q1=q2;
        while(!q2.empty()){
            q2.pop();
        }   
        return res;
    }
    int top() {
        int size=q1.size();
        size--;
        while(size--){
            q2.push(q1.front());
            q1.pop();
        }
        int res=q1.front();
        q2.push(q1.front());
        q1.pop();
        q1=q2;
        while(!q2.empty()){
            q2.pop();
        }   
        return res;
    }
    bool empty() {
        return q1.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();
 */

20. 有效的括号

法一:

cpp 复制代码
class Solution {
public:
    bool isValid(string s) {
        stack<int> st;
        for (char c : s) {
            if (c == '(') {
                st.push(1);
            } else if (c == '[') {
                st.push(2);
            } else if (c == '{') {
                st.push(3);
            } else if (c == ')') {
                if (!st.empty() && st.top() == 1) {
                    st.pop();
                } else {
                    return false;
                }
            } else if (c == ']') {
                if (!st.empty() && st.top() == 2) {
                    st.pop();
                } else {
                    return false;
                }
            } else {
                if (!st.empty() && st.top() == 3) {
                    st.pop();
                } else {
                    return false;
                }
            }
        }
        if (st.empty()) {
            return true;
        }
        return false;
    }
};

法二:

cpp 复制代码
class Solution {
public:
    bool isValid(string s) {
        unordered_map<char,char>map{{')','('},{']','['},{'}','{'}};
        stack<int> st;
        for(char c:s){
            if(map.count(c)){
                if(st.empty()||st.top()!=map[c])return false;
                st.pop();
            }
            else st.push(c);
        }
        return st.empty();
    }
};

1047. 删除字符串中的所有相邻重复项

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

优化:用string充当stack

cpp 复制代码
class Solution {
public:
    string removeDuplicates(string s) {
        string res;
        for(char c:s){
            if(res.empty()||res[res.size()-1]!=c){
                res+=c;
            }
            else {
                res.pop_back();
            }
        }
        return res;
    }
};
相关推荐
AI科技星几秒前
《全域数学》第一部 数术本源 第三卷 代数原本第14篇 附录二 猜想证明【乖乖数学】
人工智能·算法·数学建模·数据挖掘·量子计算
晓晨的博客6 分钟前
ROS1录制的bag包转换为ROS2格式
前端·chrome
shjita11 分钟前
java根据键值对中值的大小进行排序的手法。
java·开发语言·servlet
Wect14 分钟前
LeetCode 72. 编辑距离:动态规划经典题解
前端·算法·typescript
憨波个22 分钟前
【说话人日志】DOVER-Lap:overlap-aware diarization 输出融合算法
人工智能·深度学习·算法·音频·语音识别
donecoding27 分钟前
别再让 pnpm 跟着 nvm 跑了!独立安装终极指南
前端·node.js·前端工程化
GISer_Jing29 分钟前
AI全栈转型_TS后端学习路线
前端·人工智能·后端·学习
叼烟扛炮29 分钟前
C++第四讲:类和对象(下)
c++·算法·类和对象
竹林81829 分钟前
被The Graph的GraphQL查询坑了三天,我用一个真实DeFi项目把链上数据索引彻底搞懂了
前端·graphql
漫游的渔夫30 分钟前
前端开发者做 Agent:别只会执行,用 4 类失败策略让 AI 知道怎么停
前端·人工智能·typescript