一个字符串中的括号的不匹配分为左括号多,右括号多或者次序问题
在检测一个字符串中的字符如果是括号并且是左括号将它入栈,如果是右括号判断与栈顶元素是否匹配如果匹配将栈顶元素出栈如果不匹配返回false并输出括号次序不匹配。当栈为空且字符串没有遍历完且其中还有右括号时返回false输出右括号多于左括号,当字符串遍历完时栈不为空则返回false输出左括号多于右括号。只有当栈为空且遍历完字符串时括号才匹配
bool IsBrackets(const char c)
{
if ('(' == c ||'[' == c || '{' == c || ')' == c || ']' == c || '}' == c)
{
return true;
}
return false;
}
bool MatchBrackets(char arr[], size_t size)
{
stack<char> s;
size_t i = 0;
for (i = 0; i < size; i++)
{
if (IsBrackets(arr[i]))
{
if ('(' == arr[i] || '[' == arr[i] || '{' == arr[i])
{
s.push(arr[i]);
}
if (')' == arr[i] || ']' == arr[i] || '}' == arr[i])
{
if (s.empty())
{
cout << "右括号多于左括号" << endl;
return false;
}
if (')' == arr[i])
{
if ('(' == s.top())
{
s.pop();
continue;
}
}
if (']' == arr[i])
{
if ('[' == s.top())
{
s.pop();
continue;
}
}
if ('}' == arr[i])
{
if ('{' == s.top())
{
s.pop();
continue;
}
}
cout << "左右括号次序不匹配" << endl;
return false;
}
}
}
if (s.empty())
{
return true;
}
cout << "左括号多于有括号" << endl;
return false;
}