【CodeForces】[612C]Replace To Make Regular Bracket Sequence_HPU

题目要求把字符串修改为符合条件的括号的次数
必须满足左(右)括号改为另一个左(右)括号
如果不能修改就输出”Impossible”

PS:
如这种{(})也是需要修改的(2次)
所以直接在遇见左括号入栈
右括号判断与栈顶是否匹配
不相同则进行修改

#include<cstdio>
#include<stack>
#include<cstring>
using namespace std;
char s[1000200];
bool cmp(char a,char b) {
    if((a=='['&&b==']')||(a=='('&&b==')')||(a=='{'&&b=='}')||(a=='<'&&b=='>'))
        return true;
    else
        return false;
}
int main() {
    while(scanf("%s",s)!=EOF) {
        stack<char>a;
        int l=strlen(s);
        int cnt=0;
        bool flag=true;
        for(int i=0; i<l; i++) {
            if(s[i]=='['||s[i]=='<'||s[i]=='{'||s[i]=='(')
                a.push(s[i]);
            else if(s[i]==']'||s[i]=='>'||s[i]=='}'||s[i]==')') {
                if(a.empty()) {
                    flag=false;
                    break;
                } else if(!cmp(a.top(),s[i])) {
                    cnt++;
                }
                a.pop();
            }
        }
        if(!a.empty())
            flag=false;
        if(flag)
            printf("%d\n",cnt);
        else
            printf("Impossible\n");
    }
    return 0;
}

题目地址:【CodeForces】[612C]Replace To Make Regular Bracket Sequence