题目描述
给定一个只包括 '('
,')'
,'{'
,'}'
,'['
,']'
的字符串,判断字符串是否有效。
有效字符串需满足:
- 左括号必须用相同类型的右括号闭合。
- 左括号必须以正确的顺序闭合。
注意空字符串可被认为是有效字符串。
示例 1:
输入: "()" 输出: true
示例 2:
输入: "()[]{}" 输出: true
示例 3:
输入: "(]" 输出: false
示例 4:
输入: "([)]" 输出: false
示例 5:
输入: "{[]}" 输出: true
参考博客:http://www.cnblogs.com/tosser/p/9417049.html
bool isValid(char* s) {
int len = strlen(s);
int i,pos=0;
char *array = (char *)malloc(len*sizeof(len)); //新开辟一个堆存放括号的左半边
for(i=0;i<len;i++)
{
if(s[i]=='('||s[i]=='{'||s[i]=='[')
array[pos++] = s[i]; //如果是括号的左半边,存入堆
if(s[i] == ')') //如果开始出现了括号的右半边
{
if(array[pos-1] != '(') //如果括号的右半边不匹配,直接返回false
return false;
else
pos--; //否则前移出栈,只有当全部出栈时才是匹配的。
}else if(s[i] == '}')
{
if(array[pos-1]!='{')
return false;
else
pos--;
}else if(s[i] == ']')
{
if(array[pos-1]!='[')
return false;
else
pos--;
}
}
if(pos != 0) return false; //如果没有全部出栈,则不匹配。
return true;
}