判断一个括号字符串是否匹配正确,如果括号有多种,怎么做?如(([]))正确,[[(()错误。

判断一个括号字符串是否匹配正确,如果括号有多种,怎么做?如(([]))正确,[[(()错误。

创新互联从2013年成立,先为四川等服务建站,四川等地企业,进行企业商务咨询服务。为四川企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。

解题思路:可使用栈来保存符号,凡是左括号就压栈,凡是右括号就出栈,最后如果栈为空就匹配正确

    boolean isMatch(String s) { 
        Stack sk = new Stack(); 
        for (int i = 0; i < s.length(); i++) { 
            if (s.charAt(i) == '(') { 
                sk.push('('); 
            } 
            if (s.charAt(i) == ')') { 
                if (!sk.isEmpty() && sk.pop() == '(') 
                    continue; 
                else 
                    return false; 
            } 
            if (s.charAt(i) == '[') { 
                sk.push('['); 
            } 
            if (s.charAt(i) == ']') { 
                if (!sk.isEmpty() && sk.pop() == '[') 
                    continue; 
                else 
                    return false; 
            } 
        } 
        if (sk.isEmpty()) 
            return true; 
        else 
            return false; 
    }

注:栈可用于解决类似符号匹配问题


当前标题:判断一个括号字符串是否匹配正确,如果括号有多种,怎么做?如(([]))正确,[[(()错误。
转载源于:http://bzwzjz.com/article/iieeei.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 企业网站建设 古蔺网站建设 成都定制网站建设 成都网站制作 成都响应式网站建设 成都商城网站建设 手机网站建设 做网站设计 网站建设公司 成都网站设计 企业网站设计 营销型网站建设 成都网站建设 手机网站制作设计 成都网站制作 定制网站制作 网站建设推广 专业网站设计 成都网站建设 企业网站建设 营销型网站建设 重庆网站建设