【LeetCode】20.有效的括号(简单)

【被OJ毒打的第六天】LeetCode_简单_20.有效的括号

点此去做

题干:
    给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效
        1.左括号必须用相同类型的右括号闭合
        2.不同类型的括号不允许交叉
提示:
    空字符串被认为是有效字符串
输入:
    "()[]"
    "([)]"
    "{([])}"
输出:
    true
    false
    true
    

1.我的做法

执行用时:4ms,8.5MB(相当稳定)

思想:利用栈,遇到前括号全部入栈,遇到后括号时判断其与栈顶的前括号是否为同一类型:若不是,直接 return false;若是,将栈顶出栈,表示这一对括号匹配成功

实现:要考虑前括号多的情况:循环结束后判断栈是否为空,为空就说明全部括号匹配完成,可以 return true,若不为空则说明输入只有前括号;也要考虑后括号多的情况,后括号多一定会引起在某一次判断栈顶的时候栈为空,所以在判断栈顶之前加一个对栈是否为空的检验即可

bool isValid(string s) {
    stack st;
    for(char c : s) {
        if(c == '(' || c =='[' || c == '{') {
            st.push(c);
        } else {
            if(st.empty()) {
                return false;
            }
            if(c == ')' && st.top() != '(') {
                return false;
            }
            if(c == ']' && st.top() != '[') {
                return false;
            }
            if(c == '}' && st.top() != '{') {
                return false;
            }
            st.pop();
        }
    }
    if (st.empty()) {
        return true;
    } else {
        return false;
    }
}

0ms的代码其实也差不多~跑出来用时也是4ms左右~贴出来给大家看一下~

bool isValid(string s) {
    stack c_stack;
    for(int i = 0; i < s.length(); i++){
        if(!c_stack.empty() && (c_stack.top() == '(' && s[i] == ')' ||
            c_stack.top() == '{' && s[i]=='}' ||
            c_stack.top() == '[' && s[i]==']')) {
            c_stack.pop();
        } else {
            c_stack.push(s[i]);
        }
    }
    if(!c_stack.empty()) return false;
    return true;
}

最近有点感觉了?如果明天还能一发入魂 TOP 2 我就去做中等难度的题了!

加油加油加油!!!

你可能感兴趣的:(郝代码)