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

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

1.1 思路

  1. 第一种场景是左括号多余了,比如“([{}]()”;第二种场景是括号没多,但是类型不匹配,比如“[{(]}]”;第三种场景是右括号多余了,比如“[{}]())))”。注意:“[{]}”是相当于第二种情况;而“)(”相当于第三种情况,第一个右括号没有左括号匹配,就相当于多了
  2. 遍历字符串,遇到左括号时,就把对应的右括号入栈,因为这样匹配的时候直接弹出来就直接比较就可以了,方便代码实现
  3. 遇到右括号时,就判断这个右括号是否就是栈顶的右括号,是则弹出,不是则为false;此时如果右括号多了的情况,比如“[{}]())))”,当遍历到倒数第3个右括号时,此时栈里为空,说明右括号多了,则为false
  4. 最后如果栈不为空,则说明左括号多了,则为false

1.2 代码

class Solution {
    public boolean isValid(String s) {
        Stack<Character> stack=new Stack<>();
        char ch;
        for(int i=0;i<s.length();i++){
            ch=s.charAt(i);
            if(ch=='('){
                stack.push(')');
            }else if(ch=='{'){
                stack.push('}');
            }else if(ch=='['){
                stack.push(']');
            }else if(stack.empty()||stack.peek()!=ch){
                return false;
            }else{
                stack.pop();
            }
        }
        return stack.empty();
    }
}

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

2.1 思路

  1. 这题类似上述的删除括号的方式,同样是使用栈来删除的
  2. 先创建栈,然后遍历字符串,栈是用来存遍历过的元素,每遍历一个都要在栈里判断是否遍历过当前的元素/前一个元素是否就是当前的元素,如果是,当前元素就不入栈并且把栈顶元素弹出,这个操作用栈就很方便。只要栈不为空或者栈顶元素与当前元素不相同就可以直接入栈
  3. 遍历完以后栈里剩下的就是要的字符串的反向,我们可以通过一个新的空的字符串str,然后让str=stack.pop()+str; 就是把栈顶元素放到字符串的后面,这样就可以实现把栈里的元素翻转了,得到的就是我们想要的字符串

2.2 代码

class Solution {
    public String removeDuplicates(String s) {
        Stack<Character> stack=new Stack<>();
        char ch;
        for(int i=0;i<s.length();i++){
            ch=s.charAt(i);
            if(stack.empty()||stack.peek()!=ch){
                stack.push(ch);
            }else {
                stack.pop();
            }
        }
        String str="";
        while(!stack.empty()){
            str=stack.pop()+str;
        }
        return str;
    }
}

3. LeetCode 150. 逆波兰表达式求值

3.1 思路

  1. 逆波兰表达式是什么?=> 逆波兰表达式也称后缀表达式,这是方便计算机运算的 =>(1+2)*(3+4)这种就是正常习惯看的中缀表达式 =>而后缀表达式就是类似二叉树的后序遍历,在这里式子就变成了 1 2 + 3 4 + *。这样的题目就比较适合用栈来做
  2. 如何做题?遍历字符串数组,题目里是每个字符作为一个字符串,当遇到数字就入栈;当遇到运算符就出栈两个元素,第一个出栈的数字放在运算符的右边,第二个出栈的数字放在运算符的左边。注意这里顺序不能乱
  3. 将运算结果再次入栈,不断这样运行遍历,最后栈里唯一的元素则是最终运算结果
  4. 其实这题和20. 有效的括号类似,只是这里是需要三个元素,两个数字遇到一个运算符,做一个消除的操作,合成了一个数字

3.2 代码

class Solution {
    public int evalRPN(String[] tokens) {
        Stack<Integer> stack=new Stack<>();
        int temp1;
        int temp2;
        for(String s:tokens){
            if("+".equals(s)){
                temp1=stack.pop();
                temp2=stack.pop();
                stack.push(temp2+temp1);
            }else if("-".equals(s)){
                temp1=stack.pop();
                temp2=stack.pop();
                stack.push(temp2-temp1);
            }else if("*".equals(s)){
                temp1=stack.pop();
                temp2=stack.pop();
                stack.push(temp2*temp1);
            }else if("/".equals(s)){
                temp1=stack.pop();
                temp2=stack.pop();
                stack.push(temp2/temp1);
            }else{
                stack.push(Integer.valueOf(s));
            }
        }
        return stack.pop();
    }
}
相关文章
|
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
|
存储 编译器 Linux
标准库中的string类(中)+仅仅反转字母+字符串中的第一个唯一字符+字符串相加——“C++”“Leetcode每日一题”
标准库中的string类(中)+仅仅反转字母+字符串中的第一个唯一字符+字符串相加——“C++”“Leetcode每日一题”
|
15天前
|
机器学习/深度学习 索引
【力扣】387. 字符串中的第一个唯一字符
【力扣】387. 字符串中的第一个唯一字符
|
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显示图像分割效果。

热门文章

最新文章