• 力扣第20题记录


    一、题目:20. 有效的括号
    有效的括号
    二、题目解析:

    题目解析:该题需要用到数据结构当中的stack栈 (特点:后进先出)
    解题步骤:

    1. 创建一个HashMap,把括号配对放进去,维护匹配关系,{“(”:“)”}
    2. 创建一个stack,for循环遍历字符串,对于每一个字符,如果map里有这个key,那说明它是一个左括号,从map里取得相对应的右括号
      (为什么?)因为计算机不知道这些括号配对关系,需要我们自己处理,把它push进stack里。
      否则的话,它就是右括号,需要pop出stack里的第一个字符,然后看它是否等于当前的字符。如果不相符,则返回false
    3. 循环结束后,如果stack不为空,说明还剩一些左括号没有被闭合,返回false。否则返回true。

    图示帮助理解:
    在这里插入图片描述

    三、代码如下:

    public boolean isValid(String s){
            Map<Character,Character> map = new HashMap<Character, Character>(16);
            map.put('(',')');
            map.put('[',']');
            map.put('{','}');
            Stack<Character> stack = new Stack<Character>();
            for (int i = 0; i < s.length(); i++) {
                char c = s.charAt(i);
                if(map.containsKey(c)){
                    stack.push(map.get(c));
                }else{
                    if(stack.size() == 0 || stack.pop() != c){
                        return false;
                    }
                }
            }
            // 遍历完栈里面还有元素,说明还有没匹配的元素,则返回false
            if(stack.size() != 0){
                return false;
            }
            return true;
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22

    四、测试
    有效的括号

    五、结束

  • 相关阅读:
    cpu设计和实现(基础)
    轻量级的资源授权:基于 OAuth 规范
    淘宝API 接口知识小结
    lock_icon_container LockIconContainer的显示
    Vitepress搭建组件库文档(下)—— 组件 Demo
    windows Oracle Database 19c 卸载教程
    uni-app中返回顶部的方法
    糟了,线上服务出现OOM了
    Dubbo
    对象映射的那些事儿及MapStruct入门
  • 原文地址:https://blog.csdn.net/qq_39939541/article/details/127980142