首页 > 其他 > 详细

有效的括号

时间:2019-11-17 15:56:24      阅读:73      评论:0      收藏:0      [点我收藏+]

js 版本

/**
 * @param {string} s
 * @return {boolean}
 */
var isValid = function(s) {
    let stack = [];
    for(let i=0;i<s.length;i++) {
        let c = s[i];
        if(c === ( || c === [ || c === {) {
            stack.push(c)
        }
        else {
            if(stack.length ===0 ) {
                return false;
            }
            let topChar = stack.pop();
              if(c === ) && topChar != ()
                    return false;
                if(c === ] && topChar !== [)
                    return false;
                if(c === } && topChar !== {)
                    return false;
        }
    }
    if(stack.length == 0){
        return true
    }
    else{
        return false;
    }
};

java 版本

import java.util.Stack;

class Solution {

    public boolean isValid(String s) {
        Stack<Character> stack = new Stack<>();
        for(int i = 0 ; i < s.length() ; i ++){
            char c = s.charAt(i);
            if(c == ‘(‘ || c == ‘[‘ || c == ‘{‘)
                stack.push(c);
            else{
                if(stack.isEmpty())
                    return false;

                char topChar = stack.pop();
                if(c == ‘)‘ && topChar != ‘(‘)
                    return false;
                if(c == ‘]‘ && topChar != ‘[‘)
                    return false;
                if(c == ‘}‘ && topChar != ‘{‘)
                    return false;
            }
        }
        return stack.isEmpty();
    }

    public static void main(String[] args) {

        System.out.println((new Solution()).isValid("()[]{}"));
        System.out.println((new Solution()).isValid("([)]"));
    }
}

 

 

技术分享图片

 

有效的括号

原文:https://www.cnblogs.com/guangzhou11/p/11876772.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!