LeetCode热题100刷题12:20. 有效的括号、394. 字符串解码、739. 每日温度、155. 最小栈、139. 单词拆分

20. 有效的括号

cpp 复制代码
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]=='(' || s[i]=='{' || s[i]=='[')
                st.push(s[i]);
            else if(st.empty() && (s[i]=='}' || s[i]==']' || s[i]==')'))
                return false;
            else if(!st.empty()) {
                char ch = st.top();
                st.pop();
                if((ch=='(' && s[i]==')') || (ch=='[' && s[i]==']')||(ch=='{' && s[i]=='}'))
                    continue;
                else
                    return false;
            }
        }
        if(!st.empty())
            return false;
        return true;
    }
};

394. 字符串解码

cpp 复制代码
class Solution {
public:
    string getDigits(string &s, size_t &ptr) {
        string ret = "";
        while(isdigit(s[ptr])) {
            ret.push_back(s[ptr++]);
        }
        return ret;
    }
    string getString(vector<string>& v){
        string ret;
        for(const auto &s : v) {
            ret+=s;
        }
        return ret;
    }
    string decodeString(string s) {
        vector<string> stk;
        size_t ptr = 0;
        while(ptr < s.size()) {
            char cur = s[ptr];
            if(isdigit(cur)) {
                string digits = getDigits(s,ptr);
                stk.push_back(digits);
            }else if(isalpha(cur) || cur=='[') {
                stk.push_back(string(1,s[ptr++]));
            }else{
                ++ptr;
                vector<string> sub;
                while(stk.back()!="[") {
                    sub.push_back(stk.back());
                    stk.pop_back();
                }
                reverse(sub.begin(),sub.end());

                stk.pop_back();
                int repTime = stoi(stk.back());
                stk.pop_back();
                string t, o = getString(sub);

                while(repTime--)
                    t+=o;
                stk.push_back(t);
            }
        }
        return getString(stk);
    }
};

739. 每日温度

cpp 复制代码
class Solution {
public:
    vector<int> dailyTemperatures(vector<int>& temperatures) {
        if(temperatures.size()==1)
            return vector<int>(0);
        stack<int> st;
        vector<int> res(temperatures.size(),0);
        st.push(0);
        for(int i=0;i<temperatures.size();i++) {
            if(temperatures[i] <= temperatures[st.top()]) {
                st.push(i);
            }
            else {
                while(!st.empty() && temperatures[i] > temperatures[st.top()]) {
                    res[st.top()] = i-st.top();
                    st.pop();
                }
                st.push(i);
            }
        }
        return res;
    }
};

155. 最小栈

加粗借助一个栈min_st保存加入栈顶元素后当前栈的最小值

cpp 复制代码
class MinStack {
    stack<int> x_st;
    stack<int> min_st; //辅助栈,每一个元素入栈的时候都附带存储一个当前站内元素的最小值
public:
    MinStack() {
        min_st.push(INT_MAX);
    }
    
    void push(int val) {
        x_st.push(val);
        min_st.push(min(min_st.top(),val));
    }
    
    void pop() {
        x_st.pop();
        min_st.pop();
    }
    
    int top() {
        return x_st.top();
    }
    
    int getMin() {
        return min_st.top();
    }
};

/**
 * Your MinStack object will be instantiated and called as such:
 * MinStack* obj = new MinStack();
 * obj->push(val);
 * obj->pop();
 * int param_3 = obj->top();
 * int param_4 = obj->getMin();
 */

139. 单词拆分

动态规划的题

cpp 复制代码
class Solution {
public:
    bool wordBreak(string s, vector<string>& wordDict) {
        unordered_set<string> wordset(wordDict.begin(),wordDict.end());

        vector<bool> dp(s.size()+1,false);
        dp[0]=true;
        for(int i=0;i<=s.size();i++) {
            for(int j=0;j<i;j++) {
                string str = s.substr(j,i-j);
                if(wordset.find(str) != wordset.end() && dp[j])
                    dp[i]=true;
            }
        }
        return dp[s.size()];
    }
};
相关推荐
重生之我是Java开发战士1 分钟前
【优选算法】双指针法:移动0,复写0,快乐数,盛水最多的容器,有效三角形个数,二三四数之和
算法
321.。17 分钟前
深入理解 Linux 线程封装:从 pthread 到 C++ 面向对象实现
linux·开发语言·c++
EmbedLinX21 分钟前
Linux内核之文件系统:从VFS到实际存储的运作机制
linux·服务器·c语言·c++
客卿12331 分钟前
力扣二叉树简单题整理--(包含常用语法的讲解)
算法·leetcode·职场和发展
hrrrrb31 分钟前
【算法设计与分析】递归与分治策略
算法
We་ct36 分钟前
LeetCode 28. 找出字符串中第一个匹配项的下标:两种实现与深度解析
前端·算法·leetcode·typescript
血小板要健康42 分钟前
118. 杨辉三角,力扣
算法·leetcode·职场和发展
_OP_CHEN1 小时前
【算法基础篇】(五十一)组合数学入门:核心概念 + 4 种求组合数方法,带你快速熟悉组合问题!
c++·算法·蓝桥杯·排列组合·组合数学·组合数·acm/icpc
漫随流水1 小时前
leetcode回溯算法(491.非递减子序列)
数据结构·算法·leetcode·回溯算法
陳10301 小时前
C++:二叉搜索树
开发语言·数据结构·c++