ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

有效的括号

2021-05-06 18:04:51  阅读:150  来源: 互联网

标签:return 有效 top else 括号 let stack


leetcode传送门
题目大意
给定一个只包括 ‘(’,’)’,’{’,’}’,’[’,’]’ 的字符串 s ,判断字符串是否有效。

有效字符串需满足:

左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/valid-parentheses
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解题思路:

  • 用数组实现stack,top标识栈顶指针
  • 遍历字符串s,遇到左括号就压栈;遇到右括号和栈顶元素比较,两者匹配的话,栈顶元素出栈。
  • 通过栈是否为空来判断是否为有效括号

解法一:
不适用Map匹配括号

/**
 * @param {string} s
 * @return {boolean}
 */
 var isValid = function(s) {
    let stack = [];
    let top = -1;//栈顶指针
    //遍历字符串
    for( let i = 0; i < s.length; i ++) {
        if(s[i] === '(' || s[i] === '[' || s[i] === '{') {
            top ++;
            stack.push(s[i]);//压栈
        } else if(s[i] === ')' && stack[top] === '(' 
        || s[i] === ']' && stack[top] === '['
        || s[i] === '}' && stack[top] === '{') {
            stack.pop();//出栈
            top --;
        } else 
            return false;//防止右括号在左括号左边等
    }
    //通过栈是否为空来判断括号是否有效
    if( top === -1 )
        return true;
    else    
        return false;
};

解法二:
使用Map匹配括号

/**
 * @param {string} s
 * @return {boolean}
 */
 var isValid = function(s) {
    let stack = [];
    let top = -1;//栈顶指针
    let map = new Map();
    map.set("(",")");
    msp.set("[","]");
    map.set("{","}");
    for (let i = 0; i < s.length; i ++) {
        if(stack.length > s.length / 2) 
            return false;
        if(map.has(s[i])) {
            top ++;
            stack.push(s[i]);
        } else if(s[i] === map.get(stack[top])) {
            stack.pop();
            top --;
        } else 
            return false;
    }
    //通过栈是否为空来判断括号是否有效
    if( top === -1 )
        return true;
    else    
        return false;
};

说点什么

  • 使用Map匹配括号代码会简洁很多

标签:return,有效,top,else,括号,let,stack
来源: https://blog.csdn.net/sinat_33258968/article/details/116459047

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有