51nod 1791 合法括号子段 DP
2017-07-31 19:51
281 查看
思路: DP[i] 表示以i结尾的方案数,模拟一遍括号匹配过程就好了
代码:
#include<bits/stdc++.h>
using namespace std;
#define MEM(a,b) memset(a,b,sizeof(a))
#define PB push_back
#define MP make_pair
#define X first
#define Y second
#define bug puts("bug");
typedef long long ll;
typedef pair<ll,ll> pii;
const double PI=acos(-1);
const int maxn=1e6+10;
string s;
ll dp[maxn],t;
int main(){
cin>>t;
while(t--){
cin>>s;
stack<int> S;
dp[0]=0;
for(int i=0;i<s.size();i++){
if(s[i]=='('){
S.push(i+1);
}
else{
if(S.empty()) continue;
int f=S.top();
S.pop();
dp[i+1]+=dp[f-1]+1;
}
}
ll sum=0;
for(int i=0;i<=s.size();i++) sum+=dp[i],dp[i]=0;
cout<<sum<<endl;
}
return 0;
}
代码:
#include<bits/stdc++.h>
using namespace std;
#define MEM(a,b) memset(a,b,sizeof(a))
#define PB push_back
#define MP make_pair
#define X first
#define Y second
#define bug puts("bug");
typedef long long ll;
typedef pair<ll,ll> pii;
const double PI=acos(-1);
const int maxn=1e6+10;
string s;
ll dp[maxn],t;
int main(){
cin>>t;
while(t--){
cin>>s;
stack<int> S;
dp[0]=0;
for(int i=0;i<s.size();i++){
if(s[i]=='('){
S.push(i+1);
}
else{
if(S.empty()) continue;
int f=S.top();
S.pop();
dp[i+1]+=dp[f-1]+1;
}
}
ll sum=0;
for(int i=0;i<=s.size();i++) sum+=dp[i],dp[i]=0;
cout<<sum<<endl;
}
return 0;
}
相关文章推荐
- 51nod 1791 合法括号子段 (dp)
- 51nod 1791 合法括号子段(DP)
- 合法括号子段 51Nod - 1791 (栈+dp)
- 51nod 1791 合法括号子段
- 51NOD 1791 合法括号子段
- 51nod 1791 合法括号子段(模拟)
- 51Nod 1791 合法括号子段(栈+乱搞)
- 51nod 1791 合法括号子段 (队列)
- 51nod-1791-合法括号子段
- 51Nod-1791-合法括号子段
- 合法括号子段 51Nod - 1791 **
- 51nod 1791 合法括号子段
- 51 Nod 1791 合法括号子段【分治+字符串】
- 1791 合法括号子段
- 51nod_1791——合法括号字段
- 51nod 合法括号子段
- 【51nod 1791】 合法括号子段
- 【dp基础课程】矩阵取数问题+最大子段和+最长公共子序列(LCS)【51nod】
- 51Nod 1791 合法字符串 栈+动归
- 51nod 1049 1049 最大子段和 (dp)