力扣网
题目描述:给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效。
有效字符串需满足:
左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
注意空字符串可被认为是有效字符串。
class Solution {
public:
bool isValid(string s) {
stack<char> str;
for(int i = 0;i<s.size();i++){
if(!str.empty()){
if((s[i]=='}'&&str.top()=='{')||(s[i]==')'&&str.top()=='(')||(s[i]==']'&&str.top()=='[')){
str.pop();
}
else{
str.push(s[i]);
}
}
else{
str.push(s[i]);
}
}
if(str.empty()){
return true;
}
return false;
}
};
对于堆栈运用的一个最简单的例子,还有一种直接pop配对括号字符串的方法