您的位置:首页 > 其它

Leetcode 20 Valid Parentheses

2016-08-30 16:52 597 查看
Given a string containing just the characters 
'('
')'
'{'
'}'
'['
 and 
']'
,
determine if the input string is valid.

The brackets must close in the correct order, 
"()"
 and 
"()[]{}"
 are
all valid but 
"(]"
 and 
"([)]"
 are
not.
括号匹配,书上讲栈应用的一个实例,新来的和栈顶元素比较就可以了。
好在这题并没有像之前的某些题目一样丧心病狂到出各种不合常理的输入数据。

class Solution {
public:
bool isValid(string s) {
stack<char> st;
for(int i=0;i<s.length();i++)
{
if(s[i]=='(' || s[i]=='[' || s[i]=='{')
st.push(s[i]);
else
{
if(st.empty()) return false;
if((s[i]==')' && st.top()=='(') || (s[i]==']' && st.top()=='[') || (s[i]=='}' && st.top()=='{'))
st.pop();
else
return false;
}
}
return st.empty();
}
};
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: