题解 | #有效括号序列#

有效括号序列

http://www.nowcoder.com/practice/37548e94a270412c8b9fb85643c8ccc2

import java.util.*;


public class Solution {
    /**
     * 
     * @param s string字符串 
     * @return bool布尔型
     */
    public boolean isValid (String s) {
        // write code here
        
        // 一些特殊情况的处理
        if (0 == s.length()) { // 如果 String 的长度为 0,我们姑且认为它合法
            return true;
        }
        if (s.length() % 2 != 0) { // 如果 String 的长度为奇数,那么它肯定不合法
            return false;
        }
        
        Stack<Character> stack = new Stack<>(); // 定义一个 Stack,用于存放字符
        char[] chrs = s.toCharArray(); // 将字符串转换为字符数组
        boolean bool = true;
        char tmp;
        
        for (char chr : chrs) {
            if ('(' == chr || '[' == chr || '{' == chr) {
                stack.push(chr);
            }
            else {
                if (stack.isEmpty()) {
                    bool = false;
                    break;
                }
                else {
                    tmp = stack.pop();
                    if (('(' == tmp && ')' != chr) || ('[' == tmp && ']' != chr) || ('{' == tmp && '}' != chr)) {
                        bool = false;
                        break;
                    }
                }
            }
        }
        if (!stack.isEmpty()) {
            bool = false; 
        }
        return bool;
    }
}
全部评论

相关推荐

活泼的代码渣渣在泡池...:哈哈哈挺好的,我也上岸美团了,不说了,我又接了一单
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务