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

LeetCode20 栈·有效的括号(C++)

时间:2018-11-07 20:12:47      阅读:128      评论:0      收藏:0      [点我收藏+]

标签:leetcode   size   else   tco   top   symbols   字符   strong   注意   

题目描述:

给定一个只包括 ‘(‘‘)‘‘{‘‘}‘‘[‘‘]‘ 的字符串,判断字符串是否有效。

有效字符串需满足:

  1. 左括号必须用相同类型的右括号闭合。
  2. 左括号必须以正确的顺序闭合。

注意空字符串可被认为是有效字符串。

示例 1:

输入: "()"
输出: true

示例 2:

输入: "()[]{}"
输出: true

示例 3:

输入: "(]"
输出: false

示例 4:

输入: "([)]"
输出: false

示例 5:

输入: "{[]}"
输出: true


/*算法思想:*/

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

 

LeetCode20 栈·有效的括号(C++)

标签:leetcode   size   else   tco   top   symbols   字符   strong   注意   

原文地址:https://www.cnblogs.com/parzulpan/p/9924559.html

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