力扣面试150(42/150)

7.28 20. 有效的括号

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

有效字符串需满足:

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

我的思路:

长度必须为偶数,不是返回false

数组当作栈,确保每一个右括号都对应一个左括号

如果mp没有c的话->左括号,直接push

如果st长度为0,或者栈顶不为对应的括号->返回false

我的代码:

复制代码
var isValid = function(s) {
    if(s.length % 2 === 1){
        return false;
    }
    const st = [];
    const mp = {')' : '(' , ']':'[' , '}' : '{'};
    for(let c of s){
        if(!mp.hasOwnProperty(c)){
            // c是左括号
            st.push(c);
        }else if(st.length === 0 || st.pop() !== mp[c]){
            return false;
        }
    }
    return st.length === 0;
};

总结:这个函数用栈和哈希表来检查括号字符串是否有效。先检查长度是否为奇数,如果是直接返回false。然后遍历字符串,遇到左括号就压栈,遇到右括号就检查栈顶是否匹配,不匹配或栈空就返回false。最后检查栈是否为空,空则有效。

相关推荐
AI 嗯啦2 小时前
数据结构深度解析:二叉树的基本原理
数据结构·算法
和光同尘@3 小时前
66. 加一 (编程基础0到1)(Leetcode)
数据结构·人工智能·算法·leetcode·职场和发展
CHEN5_023 小时前
leetcode-hot100 11.盛水最多容器
java·算法·leetcode
songx_993 小时前
leetcode18(无重复字符的最长子串)
java·算法·leetcode
max5006004 小时前
实时多模态电力交易决策系统:设计与实现
图像处理·人工智能·深度学习·算法·音视频
其古寺4 小时前
贪心算法与动态规划:数学原理、实现与优化
算法·贪心算法·动态规划
rit84324995 小时前
基于灰狼算法(GWO)优化支持向量回归机(SVR)参数C和γ的实现
c语言·算法·回归
蒋士峰DBA修行之路5 小时前
实验五 静态剪枝
数据库·算法·剪枝
蒋士峰DBA修行之路5 小时前
实验六 动态剪枝
数据库·算法·剪枝
Tim_105 小时前
【算法专题训练】20、LRU 缓存
c++·算法·缓存