码迷,mamicode.com
首页 > 编程语言 > 详细

LeetCode 20. Valid Parentheses(c++)

时间:2019-04-28 20:39:02      阅读:171      评论:0      收藏:0      [点我收藏+]

标签:als   str   int   har   leetcode   i++   nbsp   c++   ack   

利用栈的操作,遇到"(","[","{"即进栈,遇到")","]","}"判断是否与栈顶匹配,若不匹配则false。

class Solution {
public:
    bool isValid(string s) {
        stack<char> c;
        for(int i=0;i<s.size();i++){
            if(!c.empty()){
            if(s[i]==(||s[i]=={||s[i]==[)
                c.push(s[i]);
            else if(s[i]==)){
                if(c.top()==() c.pop();
                else return false;
            }
            else if(s[i]==}){
                if(c.top()=={) c.pop();
                else return false;
            }
            else if(s[i]==]){
                if(c.top()==[) c.pop();
                else return false;
            }
            }
            else c.push(s[i]);
        }
        if(!c.empty()) return false;
        return true;
    }
};

 

LeetCode 20. Valid Parentheses(c++)

标签:als   str   int   har   leetcode   i++   nbsp   c++   ack   

原文地址:https://www.cnblogs.com/y1040511302/p/10786203.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!