筱玛的字符串

思路 :dp [ i ] [ j ] [ 3 ] 分别代表到第 i 位时 左括号比右括号多 j ,后面有三个状态 分别表示当前位置 S3的字符

是正在反转的,还是 反转完成的,还是没有反转的, 根据提议要求 反转的只能是一段连续区间,然后转移即可。

注意 反转完成之后 不能再开始一段新的反转过程 。

#include<bits/stdc++.h>
using namespace std;
#define mod 1000000007
#define ll long long
#define maxn 3456
ll dp[maxn][maxn][5];
char s[maxn];
int main()
{
dp[0][0][0]=1;
scanf("%s",s+1);
int len=strlen(s+1);
for(int i=1; i<=len; i++)
{
for(int j=0; j<=i; j++)
{
if(s[i]=='?')
{
if(j!=0)
{
dp[i][j-1][0]+=(dp[i-1][j][0]);
dp[i][j-1][0]%=mod;
dp[i][j-1][1]+=(dp[i-1][j][0]+dp[i-1][j][1]);
dp[i][j-1][1]%=mod;
dp[i][j-1][2]+=(dp[i-1][j][1]+dp[i-1][j][2]);
dp[i][j-1][2]%mod;
}
dp[i][j+1][0]+=(dp[i-1][j][0]);
dp[i][j+1][0]%=mod;
dp[i][j+1][1]+=(dp[i-1][j][0]+dp[i-1][j][1]);
dp[i][j+1][1]%=mod;
dp[i][j+1][2]+=(dp[i-1][j][1]+dp[i-1][j][2]);
dp[i][j+1][2]%=mod;
}
else if(s[i]=='(')
{
if(j!=0)
dp[i][j-1][1]+=(dp[i-1][j][0]+dp[i-1][j][1]);
dp[i][j-1][1]%=mod;
dp[i][j+1][2]+=(dp[i-1][j][1]+dp[i-1][j][2]);
dp[i][j+1][2]%=mod;
dp[i][j+1][0]+=(dp[i-1][j][0]);
dp[i][j+1][0]%mod;
}
else
{
if(j!=0)
{
dp[i][j-1][2]+=(dp[i-1][j][1]+dp[i-1][j][2]);
dp[i][j-1][2]%mod;
dp[i][j-1][0]+=(dp[i-1][j][0]);
dp[i][j-1][0]%mod;
}
dp[i][j+1][1]+=(dp[i-1][j][0]+dp[i-1][j][1]);
dp[i][j+1][1]%mod;
}
}
}
ll ans=(dp[len][0][1]+dp[len][0][0]+dp[len][0][2])%mod;
printf("%lld\n",ans);
return 0;
}

  

牛客练习赛37-筱玛的字符串-DP递推的更多相关文章

  1. 牛客练习赛37C 筱玛的迷阵探险 双向搜索+字典树

    题意 筱玛是个快乐的男孩子.寒假终于到了,筱玛决定请他的朋友们一起来玩迷阵探险.迷阵可以看做一个的矩阵A,每个格子上有一个有一个数Ai,j.入口在左上角的(1,1)处,出口在右下角的(n,n)处.每一 ...

  2. 牛客练习赛36 A Rabbit的字符串(字符串最小表示法)

    链接:https://ac.nowcoder.com/acm/contest/328/A来源:牛客网 题目描述 Rabbit得到了一个字符串,她的好朋友xxx可以给这个字符串施加一次魔法. 魔法可以选 ...

  3. 牛客练习赛24题解(搜索,DP)

    A题,C题不讲,基础题(但是我要抨击一下这次比赛,卡cin,cout,卡的太狠了,根本就不让过的那种,QAQ) 链接:https://www.nowcoder.com/acm/contest/157/ ...

  4. 牛客练习赛70 A.重新排列 (,字符串思维)

    题意:有一个模板串,给你\(T\)个字符串,选取最短的子串,使其重新排列后包含模板串,求最短的子串的长度 题解:遍历字符串,记录每个字符出现的最后位置,每记录一个后再遍历子串,找到子串需要的所有的字符 ...

  5. 牛客练习赛 26 B题 烟花【DP】(经典)

    <题目链接> 题目描述 小a有个烟花,每个烟花代表着互不相同的颜色,对于第个烟花,它有的概率点燃,现在小a要去点燃它们,他想知道产生颜色的期望个数 及 产生恰好产生种颜色的概率 输入描述: ...

  6. 牛客练习赛18E pocky游戏 状压dp

    正解:状压dp+辅助dp 解题报告: 来还债辣!NOIp之后还是轻松很多了呢,可以一点点儿落实之前欠下的各种东西一点点提升自己!加油鸭! 是个好题,可以积累套路,启发性强,而且很难 哦而且状压它也是个 ...

  7. 牛客练习赛32B Xor Path (树形dp)

    时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言524288K 64bit IO Format: %lld 题目描述 给定一棵n个点的树,每个点有权值.定义表示 ...

  8. 牛客练习赛79E-小G的数学难题【dp,单调队列】

    正题 题目链接:https://ac.nowcoder.com/acm/contest/11169/E 题目大意 给出\(n\)个三元组\((a_i,b_i,c_i)\). 要求选出一个集合\(S\) ...

  9. 牛客练习赛53 A 超越学姐爱字符串 (DP)

    牛客练习赛53 超越学姐爱字符串 链接:https://ac.nowcoder.com/acm/contest/1114/A来源:牛客网 超越学姐非常喜欢自己的名字,以至于英文字母她只喜欢" ...

随机推荐

  1. vue 树状图数据的循环 递归循环

    在main.js中注册一个子组件 在父组件中引用 树状图的数据格式 绑定一个数据传入子组件,子组件props接收数据 子组件中循环调用组件,就实现了递归循环

  2. LeetCode(94):二叉树的中序遍历

    Medium! 题目描述: 给定一个二叉树,返回它的中序 遍历. 示例: 输入: [1,null,2,3] 1 \ 2 / 3 输出: [1,3,2] 进阶: 递归算法很简单,你可以通过迭代算法完成吗 ...

  3. springboot动态多数据源切换

    application-test.properties #datasource -- mysql multiple.datasource.master.url=jdbc:mysql://localho ...

  4. tomcat和server安装和操作

    servers的创建 最后一步:ctrl+s

  5. Linux进程管理工具

    Linux进程管理工具 Htop yum install htop 参考帮助: http://blog.csdn.net/skh2015java/article/details/53173896 Li ...

  6. Android实时取景:用SurfaceView实现

    对于基于摄像头的Android应用,实时取景是一个基本前提,通过前置或后置摄像头持续获取捕获到的内容,可以进一步做处理(人脸检测.美颜.滤镜等). 所谓实时取景,简单说就是调用android的摄像头, ...

  7. Asp.Net MVC Ajax轮训解决Session失效时间

    这种方法不是太好,对服务器得压力大,由于系统是内部人员使用,业务有比较复杂,所以有些值得需要Session去保存,但是,Session有失效时间. 代码如下: $(function () { func ...

  8. MongDb介绍及简单实用

       一:介绍       MongoDB是一个高性能,开源,无模式的文档型数据库,是当前NoSql数据库中比较热门的一种.它在许多场景下可用于替代传统的关系型数据库或键/值存储方式.Mongo使用C ...

  9. |ERROR|ERROR: missing data for column "createtime" (seg3 slice1 192.168.66.23:40001 pid=33370)之mysql换行符或者空格引起的问题

    1.最近的kettle的数据交换配置,启动kettle引起的错误,如下所示: |ERROR|ERROR: missing data pid=) 引发这个错误,并不是这个字段引起的错误,一般是这个字段临 ...

  10. 一脸懵逼学习MapReduce的原理和编程(Map局部处理,Reduce汇总)和MapReduce几种运行方式

    1:MapReduce的概述: (1):MapReduce是一种分布式计算模型,由Google提出,主要用于搜索领域,解决海量数据的计算问题. (2):MapReduce由两个阶段组成:Map和Red ...