代码随想录算法训练营第11天 | 20. 有效的括号, 1047. 删除字符串中的所有相邻重复项,150. 逆波兰表达式求值

简介: 代码随想录算法训练营第11天 | 20. 有效的括号, 1047. 删除字符串中的所有相邻重复项,150. 逆波兰表达式求值

20. 有效的括号

代码

class Solution {
public:
    bool isValid(string s) {
        stack<char>s_s;
        //返回条件:
        //1 遍历结束 栈不为空 返回false,因为符号与栈顶匹配的都被pop出了
        //2 遍历途中栈为空,待插入字符为括号右边符号则直接返回false;一开始就是右边符号肯定是错误的
        //3 遍历途中栈不为空,符号不等于栈顶值且是括号右边值则直接返回 false;同理等待插入的符号为符号左边那一定是错误的,因为括号位置左右反了。
        for(int i = 0;i< s.size();++i){
            char val = s[i];
                if(!s_s.empty() && val==s_s.top()){
                    s_s.pop();
                }else{
                    switch (val){
                        case '(' : s_s.push(')');break;
                        case '[' : s_s.push(']');break;
                        case '{' : s_s.push('}');break;
                        default :return false; //栈为空且字符为括号右边,直接返回false;
                    }
                }
        }
        return s_s.empty();
    }
};

思路

使用栈先入后出的属性可以实现,栈插入的字符全部是括号右边。

1 栈为空的情况下要插入的字符是左边括号则直接返回false;因为一开始的插入了左侧括号后面是无法在括号规则正确的情况下弹出括号的。如“)(”,遍历找到了‘)’则要插入的符号为‘(’,显然这是不可以的。

2 栈不为空的情况下栈顶值不等于当前遍历的字符,且字符为右边括号,直接返回false;因为栈顶值不等于当前被遍历的字符,则说明当前括号的右边括号是准备被插入的字符,如果括号本身已经是右边字符则无法插入,说明该括号是一个不配对的字符。如“{ } { ) }”‘{’插入的是‘}’,‘}’与栈顶值‘}’相等

所以pop掉,同样地,第三个字符‘{’要插入栈顶的是‘}’,‘)’不等于栈顶部值,则‘)’会被作为一个要插入栈顶的字符,但是如果插入了则后面就不会有右边字符与其匹配,所以不能插入,字符串括号不匹配。

3 遍历结束后栈为空则返回ture,否则返回false;

难点

上述三点一开始不太好想到。

总结

简单题。主要加深对栈的使用。

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

代码

class Solution {
public:
    string removeDuplicates(string s) {
        string res;
        for(char val :s){
            if(!res.empty() && val == res.back()){
                res.pop_back();
            }else{
                res.push_back(val);
            } 
        }
        return res;
    }
};

思路

采用栈的思想,遍历字符,如果栈内的字符和当前字符相等则将其弹出,继续下一层遍历,直到所有字符都遍历完成,栈内剩下的字符就是不相邻的字符,将其反转就可以得到结果

难点

不难

总结

也是考察对栈的使用

150. 逆波兰表达式求值

代码

class Solution {
public:
    int evalRPN(vector<string>& tokens) {
        stack<long long> number;
        for(string val : tokens){
            if(val == "+"||val=="-"||val=="*"||val=="/"){
            long long res1  = number.top();
            number.pop();
            long long res2 = number.top();
            number.pop();
            if(val == "+") number.push(res2 + res1);
            if(val == "-") number.push(res2 - res1);
            if(val == "*") number.push(res2 * res1);
            if(val == "/") number.push(res2 / res1);
            }else{ 
                number.push(stoi(val));
            }
        }
        return number.top();
    }
};

思路

遍历字符,将不等于+-*/的字符全部转换成数字存入站内,字符串的前面一定是数字字符。所以遍历到+-*/时就可以栈顶两个元素弹出,计算出结果后在插入栈顶,直到遍历结束,栈顶值就是逆波兰表达式的结果。

难点

要理解什么是逆波兰表达式。

总结

深入理解了栈这种数据结构。

参考来源

有效括号:https://programmercarl.com/0020.%E6%9C%89%E6%95%88%E7%9A%84%E6%8B%AC%E5%8F%B7.html

删除字符串中的所有相邻重复项:https://programmercarl.com/1047.%E5%88%A0%E9%99%A4%E5%AD%97%E7%AC%A6%E4%B8%B2%E4%B8%AD%E7%9A%84%E6%89%80%E6%9C%89%E7%9B%B8%E9%82%BB%E9%87%8D%E5%A4%8D%E9%A1%B9.html

逆波兰表达式:https://programmercarl.com/0150.%E9%80%86%E6%B3%A2%E5%85%B0%E8%A1%A8%E8%BE%BE%E5%BC%8F%E6%B1%82%E5%80%BC.html#%E7%AE%97%E6%B3%95%E5%85%AC%E5%BC%80%E8%AF%BE

相关文章
|
11天前
|
算法
代码随想录算法训练营第六十天 | LeetCode 84. 柱状图中最大的矩形
代码随想录算法训练营第六十天 | LeetCode 84. 柱状图中最大的矩形
18 3
|
11天前
|
算法
代码随想录算法训练营第五十七天 | LeetCode 739. 每日温度、496. 下一个更大元素 I
代码随想录算法训练营第五十七天 | LeetCode 739. 每日温度、496. 下一个更大元素 I
14 3
|
11天前
|
算法
代码随想录算法训练营第五十六天 | LeetCode 647. 回文子串、516. 最长回文子序列、动态规划总结
代码随想录算法训练营第五十六天 | LeetCode 647. 回文子串、516. 最长回文子序列、动态规划总结
31 1
|
11天前
|
算法
代码随想录算法训练营第五十五天 | LeetCode 583. 两个字符串的删除操作、72. 编辑距离、编辑距离总结
代码随想录算法训练营第五十五天 | LeetCode 583. 两个字符串的删除操作、72. 编辑距离、编辑距离总结
22 1
|
20天前
|
算法
【算法学习--字符串】(不含KMP算法)
【算法学习--字符串】(不含KMP算法)
|
2月前
|
机器学习/深度学习 算法
m基于深度学习的64QAM调制解调系统频偏估计和补偿算法matlab仿真
### 算法仿真结果 展示5张图像,描绘了基于深度学习的频偏估计和补偿在MATLAB 2022a中的仿真效果。 ### 理论概要 - 深度学习算法用于建立信号与频偏的非线性映射,无需导频,节省资源。 - 网络模型(如CNN或RNN)处理IQ数据,提取特征,简化估计补偿过程,降低复杂度。 - 64QAM系统中,通过神经网络实现精确频偏感知,增强通信性能。 ### MATLAB核心程序 - 代码生成64QAM信号,模拟不同SNR和频偏条件,使用深度学习进行相位估计和补偿。 - 仿真比较了有无补偿的误码率,显示补偿能显著改善通信质量。 ```
31 1
|
10天前
|
机器学习/深度学习 人工智能 算法
基于DCT和扩频的音频水印嵌入提取算法matlab仿真
本文介绍了结合DCT和扩频技术的音频水印算法,用于在不降低音质的情况下嵌入版权信息。在matlab2022a中实现,算法利用DCT进行频域处理,通过扩频增强水印的隐蔽性和抗攻击性。核心程序展示了水印的嵌入与提取过程,包括DCT变换、水印扩频及反变换步骤。该方法有效且专业,未来研究将侧重于提高实用性和安全性。
|
25天前
|
机器学习/深度学习 算法
【MATLAB】GA_BP神经网络时序预测算法
【MATLAB】GA_BP神经网络时序预测算法
33 8
|
29天前
|
机器学习/深度学习 算法 Serverless
【MATLAB】PSO_BP神经网络回归预测算法(适用光伏发电回归预测等)
【MATLAB】PSO_BP神经网络回归预测算法(适用光伏发电回归预测等)
30 1
|
1天前
|
算法 TensorFlow 算法框架/工具
基于直方图的图像阈值计算和分割算法FPGA实现,包含tb测试文件和MATLAB辅助验证
这是一个关于图像处理的算法实现摘要,主要包括四部分:展示了四张算法运行的效果图;提到了使用的软件版本为VIVADO 2019.2和matlab 2022a;介绍了算法理论,即基于直方图的图像阈值分割,通过灰度直方图分布选取阈值来区分图像区域;并提供了部分Verilog代码,该代码读取图像数据,进行处理,并输出结果到&quot;result.txt&quot;以供MATLAB显示图像分割效果。