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

LeetCode 20. 有效的括号

题目链接:20. 有效的括号

思路:栈最经典的题目了。思路想到其实就很简单了(虽然我一开始没想到)。其实仔细分析会发现不匹配的情况下无非三种。第一种 左符号多余 第二种右符号多余 第三种括号不匹配。我们依次遍历给的的括号字符串数组 当遇到左括号时将对应的右括号入栈,当遍历到与栈顶元素相同的元素时候即可出栈,代表两个括号已经进行匹配。如果栈一直为空则代表没有对应的左括号 或者 遍历到的不为左括号的右括号与括号字符串数组的值不相同则返回false 最终如果整个栈不为空的话则返回false否则返回true

具体实现:

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

        return stack.isEmpty();

    }
}

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

题目链接:1047. 删除字符串中的所有相邻重复项

思路:这道题看着难,但是想到用栈来解决就很简单。可以用栈来保存当前元素的前一个元素的值,如果当前元素的值与栈里的元素相同则就代表相邻两个元素一样,可以消掉。先依次遍历数组元素。如果遍历到元素与栈中的元素不同则该元素入栈。如果相同,让栈里的元素出栈(即消去相同的元素)因为栈里的元素是当前指向的元素前一个元素,这两个元素要是一样的,栈里的元素一出栈,则这两个一样的元素都不会在栈里存在。而指针又能指向下一个元素。继续用栈顶元素与下一个元素判断是否相同。当栈空的情况例如aabbc消去aa和bb之后栈肯定为空此时只剩下c,c直接入栈即可。这样就保证栈里的元素就是没有相邻重复的项了。

具体实现:

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

    }
}

LeetCode 150. 逆波兰表达式求值

题目链接:150. 逆波兰表达式求值

思路:由于本题给出的即是逆波兰表达式,所以难度大大下降了,我一开始还要要自己写出一个中缀表达式的后缀表达式。计算机在进行计算时候都是用后缀表达式进行计算。遇到操作数即入栈,遇到运算符弹出栈顶的两个元素后一个元素 OP 前一个元素 后再放入栈中。依次直到遍历完整个后缀表达式

具体实现:

lass Solution {
    public int evalRPN(String[] tokens) {
        Stack<Integer> stack = new Stack();
        for (int i = 0; i < tokens.length; i++) {
            if(tokens[i].equals("+")||tokens[i].equals("-")||tokens[i].equals("*")||tokens[i].equals("/")){
                int num1=stack.peek();
                stack.pop();
                int num2=stack.peek();
                stack.pop();
                if(tokens[i].equals("+")){
                    stack.push(num2+num1);
                }
                if(tokens[i].equals("-")){
                    stack.push(num2-num1);
                }
                if(tokens[i].equals("*")){
                    stack.push(num2*num1);
                }
                if(tokens[i].equals("/")){
                    stack.push(num2/num1);
                }
            }else {
                stack.push(Integer.valueOf(tokens[i]));
            }
        }

        return stack.pop();
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值