博客
关于我
51Nod 1791 合法括号子段
阅读量:413 次
发布时间:2019-03-06

本文共 1091 字,大约阅读时间需要 3 分钟。

给定一串括号串,对于其中每个左括号‘(’最多只能找到一个与之相匹配的右括号‘)’。显然,在括号串固定的情况下,括号的匹配是固定不变的。根据题意,空串为合法括号,“()”为合法括号串,若A为合法括号串则”(A)”为合法括号串。那么我们可以先用括号匹配算法(利用栈)可以找出独立括号的配对情况。假设括号匹配对用数组pos[N]表示,初始化为-1,代表没有与之匹配的括号(右括号最终值是-1),pos[i]表示在第pos[i]个位置上的右括号与第i个左括号匹配。即若pos[i]≠−1,第i个位置上肯定是左括号,第pos[i]个位置上肯定是右括号。

找出独立括号后,以每个括号为开头计算以该括号开头,能有多少对合法的括号序列。用ans[i]存储答案,ans[i]表示以第i个括号开始能有多少种合法的序列,状态转移方程:

$$ans[i]=ans[pos[i]+1]+1  i!=-1$$最后$Ans=\sum_{i=0}^{len-1}ans[i]$
#include 
using namespace std;#define ll long long#define F(i,a,b) for(int i=a;i<=b;++i)#define R(i,a,b) for(int i=a;i
S;int main(){ for(scanf("%d",&t);t--;) { scanf("%s",s); int len=strlen(s); R(i,0,len) pos[i]=-1,ans[i]=0; while(!S.empty()) S.pop(); R(i,0,len) { if(s[i]=='(') { S.push(i);continue; } if(S.empty()) continue; pos[S.top()]=i;S.pop(); } ll Ans=0; for(int i=len-1;i>=0;--i) { if(pos[i]==-1) continue; ans[i]=ans[pos[i]+1]+1; Ans+=ans[i]; } printf("%I64d\n",Ans ); } return 0;}

转载地址:http://rkokz.baihongyu.com/

你可能感兴趣的文章
mysql 多个表关联查询查询时间长的问题
查看>>
mySQL 多个表求多个count
查看>>
mysql 多字段删除重复数据,保留最小id数据
查看>>
MySQL 多表联合查询:UNION 和 JOIN 分析
查看>>
MySQL 大数据量快速插入方法和语句优化
查看>>
mysql 如何给SQL添加索引
查看>>
mysql 字段区分大小写
查看>>
mysql 字段合并问题(group_concat)
查看>>
mysql 字段类型类型
查看>>
MySQL 字符串截取函数,字段截取,字符串截取
查看>>
MySQL 存储引擎
查看>>
mysql 存储过程 注入_mysql 视图 事务 存储过程 SQL注入
查看>>
MySQL 存储过程参数:in、out、inout
查看>>
mysql 存储过程每隔一段时间执行一次
查看>>
mysql 存在update不存在insert
查看>>
Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
查看>>
Mysql 学习总结(87)—— Mysql 执行计划(Explain)再总结
查看>>
Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
查看>>
Mysql 学习总结(89)—— Mysql 库表容量统计
查看>>
mysql 实现主从复制/主从同步
查看>>