【数据结构】关于栈的经典算法题

文章目录

1:有效的括号匹配

给定一个只包括 '(',')','{','}','[',']' 的字符串 s ,判断字符串是否有效。

有效字符串需满足:

左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
每个右括号都有一个对应的相同类型的左括号。

代码实现

public boolean isValid(String s) {
        if (s == null || s.equals("")) {
            return false;
        }
        Stack<Character> st = new Stack<>();
        for (int i = 0; i < s.length(); i++) {
            char ch = s.charAt(i);
            if (ch == '(' || ch == '[' || ch == '{') {
                st.push(ch);
            } else {
                if (st.isEmpty()) {
                    return false;
                }
                char top = st.peek();
                if (top == '(' && ch == ')' ||
                        top == '[' && ch == ']' ||
                        top == '{' && ch == '}') {
                    st.pop();
                } else{
                    return false;
                }
            }
        }
        return st.isEmpty();
    }

2:.逆波兰表达式求值

有效的算符包括 +-*/ 。每个运算对象可以是整数,也可以是另一个逆波兰表达式。

tokens = ["2","1","+","3","*"] 转化为算术表达式为:((2 + 1) * 3) = 9

代码实现

    public int evalRPN(String[] tokens) {
 if(tokens==null||tokens.length==0){
            return 0;
        }
        Stack<Integer> stack=new Stack<>();
        for(int i=0;i<tokens.length;i++){
            String s=tokens[i];
            if(isNumber(s)){
                int number=Integer.parseInt(s);
                stack.push(number);
            }else{
                int m=stack.pop();
                int n=stack.pop();
          switch(s){
       case "+":stack.push(n+m);
       break;
       case "-":stack.push(n-m);
        break;
       case "*":stack.push(n*m);
        break;
       case "/":stack.push(n/m);
        break;
       default:
          }
        }
        
    }
    return stack.pop();
    }
        public static boolean isNumber(String s){
        return !(s.equals("+")||s.equals("-")||s.equals("*")||s.equals("/"));
    }

3.栈的压入,弹出序列

输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序。

[1,2,3,4,5],[4,5,3,2,1]

返回True

[1,2,3,4,5],[4,3,5,1,2]

返回False;

代码实现

    public boolean IsPopOrder(int [] pushA, int [] popA) {
        //非空检验
        if (pushA == null || pushA.length == 0) {
            return  false;
        }
        Stack<Integer> stack = new Stack<>();
        int j = 0;
        for (int i = 0; i < pushA.length; i++) {
            stack.push(pushA[i]);
            while (!stack.isEmpty() && stack.peek() == popA[j]) {
                j++;
                stack.pop();
            }
        }
        return stack.isEmpty();
    }

  • 5
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jhpan666

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值