C++ 括号匹配的检验

#include
#include
#include
using namespace std;
stack s;
int main()
{
bool state=true;
   string exp;
   cin>>exp;
   for(int i=0;i   {
      switch(exp[i])
 {
 case '(':
 {
 s.push('(');break;
 }
 case ')':
 {
 if(!s.empty()&&s.top()=='(')
 {
                  s.pop();
 break;
 }else
 {
    state=false;
break;
 }


 }


  case '[':
 {
 s.push('[');break;
 }
 case ']':
 {
 if(!s.empty()&&s.top()=='[')
 {
                  s.pop();
 break;
 }else
 {
    state=false;
break;
 }


 }


   case '{':
 {
 s.push('{');break;
 }
 case '}':
 {
 if(!s.empty()&&s.top()=='{')
 {
                  s.pop();
 break;
 }else
 {
    state=false;
break;
 }


 }


 }
   }
   if(s.empty()&&state)
   {
  cout<<"正确";
   }
   else
   {
      cout<<"错误";
   }




return 0;
}

你可能感兴趣的:(C++ 括号匹配的检验)