题目描述
牛牛最近在学习括号匹配问题
给你一个合法的括号序列,每次操作分两步,第一步删除第一个左括号,第二步删除某一个右括号,要保证删除之后的括号序列还是合法的,求将括号删到空为止一共有多少种不同的删除方法,两种方法不同当且仅当存在某一步右括号的删除位置不同,答案膜1e9+7
题目中并没有说括号没有删完会怎么样 隐含的意思就是一定可以删完 如果聪明的你已经想到了就当这句是废话
从右括号看前面有几个还没匹配的括号,然后每次遍历到')' ans就加上ans乘上前面剩余左括号的个数 就是这题的答案 小贪心吧 (毕竟是从贪心分类里找出来打的题目)
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn = 3000;
char str[maxn];
const int mod=1e9+7;
int main()
{
cin>>str;
int t=0;
long long ans=1;
for(int i=0;i<strlen(str);i++){
if(str[i]=='('){
t++;
}
else{
ans=(ans%mod*t%mod)%mod;
t--;
}
}
cout<<ans<<endl;
return 0;
}