[NOI online2022普及C]字符串
题目描述
Kri 非常喜欢字符串,所以他准备找 \(t\) 组字符串研究。
第 \(i\) 次研究中,Kri 准备了两个字符串 \(S\) 和\(R\) ,其中 \(S\) 长度为 \(n\),且只由 \(0, 1, -\) 三种字符构成(注:这里的第三种字符是减号),\(R\) 初始时为空。
每次研究,Zay 会带着一个美丽的长度为 \(m\) 的字符串 \(T\) 来找 Kri 玩,Kri 非常羡慕 Zay 拥有如此美丽的字符串,便也想用字符串 \(S\) 和 \(R\) 变出字符串 \(T\)。
具体地,Kri 将会进行 \(n\) 次操作。每次操作中,Kri 会取出 \(S\) 的第一个字符(记为 \(c\)),并将其从 \(S\) 中删去。如果 \(c = \texttt{-}\),则 Kri 要删去 \(R\) 的开头字符或结尾字符(数据保证删去后 \(R\) 不为空)。否则,Kri 会将 \(c\) 加入到 \(R\) 的末尾。
当进行完所有操作后,Kri 会检查 \(R\) 是否和 \(T\) 相等。如果 \(R=T\),Kri 就会感到开心;否则,Kri 会感到难受。
请问在每次研究中,Kri 有多少种操作方式使自己最后感到开心?我们定义两种方案不同,当且仅当在某种方案的某次操作中, Kri 删去了 \(R\) 的开头字符。而在另一种方案的这次操作中, Kri 删去了 \(R\) 的结尾字符。
由于答案可能很大,你只需要输出答案除以 \(1,000,000,007\)(即 \(10^9+7\))的余数。
输入格式
第一行一个正整数 tt。
接下来有 tt 组数据分别表示 tt 次字符串的研究,对于每组数据:
第一行有两个正整数 n,mn,m,分别表示字符串 S,TS,T 的长度。
第二行是字符串 SS。
第三行是字符串 TT。
输出格式
共 tt 行,第 ii 行表示第 ii 组研究的答案。
输入输出样例
输入 #1
3
6 2
10-01-
01
7 3
010-1-1
101
6 4
111-00
1100
输出 #1
2
1
2
输入 #2
见附件中的 string2.in
输出 #2
见附件中的 string2.out
说明/提示
【样例 1 解释】
对于第一组数据,有以下两种方案:
第一个 - 删 \(R\) 的开头,第二个 - 删 \(R\) 的结尾。
第一个 - 删 \(R\) 的结尾,第二个 - 删 \(R\) 的开头。
【数据范围】
对于 \(20\%\) 的数据,\(n,m\le 15\)。
对于 \(30\%\) 的数据,\(n,m\le 30\)。
对于 \(70\%\) 的数据,\(n,m\le 80\)。
对于另 \(10\%\) 的数据,保证答案不超过 \(1\)。
对于 \(100\%\) 的数据,\(1\le t\le 5\),\(1\le n,m\le 400\)。
每一个字符有几种可能。要不就是在前面被删去,要不就是在后面被删去,要不就是保持着不被删去。设现在有\(x\)个已匹配,\(y\)个在前面被删,\(z\)个在后面被删。然后做dp。我们来考虑在哪些情况下能执行那些操作。
首先如果现在遇到了一个减号,那么在前面的数只能在有可以删的数时才能删,后面的数同理。这个转移相对简单。
如果不是减号呢?首先如果我们要把它归为不被删去的数,就要把他与匹配串的下一位比较,如果一样才可以转移。同时必须后面没有要被删的数。
如果我们要把它归为在前面删的数,那么就要在既没有不被删的数也没有在后面删的数时,这个数才能在前面删。
如果我们把它归为在后面删的数,其实什么时候都可以。然后我们的dp就完成了。
当这个dp如果加上计算已经到达了哪一位这一维度,看似会超时,当其实,我们可以通过x,y,z算出到了哪一位置,把他们全部加起来就好了。
#include<cstdio>
#include<cstring>
const int N=405,P=1e9+7;
char c[N],s[N];
int t,n,m,f[N][N][N];
int dfs(int t,int x,int y,int z)
{
if(t==n)
return x==m;
int ret=0;
if(f[t][x][y]!=-1)
return f[t][x][y];
if(c[t]=='-')
{
if(y)
ret+=dfs(t+1,x,y-1,z);
if(z)
ret+=dfs(t+1,x,y,z-1);
return f[t][x][y]=ret%P;
}
if(c[t]==s[x]&&!z)
ret=dfs(t+1,x+1,y,z);
ret=(ret+dfs(t+1,x,y,z+1))%P;
if(!x&&!z)
ret=(ret+dfs(t+1,x,y+1,z))%P;
return f[t][x][y]=ret;
}
int main()
{
scanf("%d",&t);
while(t--)
{
scanf("%d%d%s%s",&n,&m,c,s);
memset(f,-1,sizeof(f));
printf("%d\n",dfs(0,0,0,0));
}
}
[NOI online2022普及C]字符串的更多相关文章
- [NOI.AC#34]palinedrome 字符串hash+贪心
容易看出,只要从两边往中间扫描,碰到相等的就直接分割然后加入答案即可,判断相等用字符串hash #include<bits/stdc++.h> #define REP(i,a,b) for ...
- 牛客网NOIP赛前集训营-普及组(第一场)
前三题略 T4: 题目描述 小A有n个长度都是L的字符串.这些字符串只包含前8个小写字符,'a'~'h'.但这些字符串非常的混乱,它们几乎长得互不相同.小A想通过一些规则,让它们长得尽可能相同.小A现 ...
- [CQOI2014][bzoj3507] 通配符匹配 [字符串hash+dp]
题面 传送门 思路 0x01 KMP 一个非常显然而优秀的想法:把模板串按照'*'分段,然后对于每一段求$next$,'?'就当成可以对于任意字符匹配就行了 对于每个文本串,从前往后找第一个可以匹配的 ...
- CSP2019-S2参赛总结 暨 近期学习反思
前言 岁月不居,时节如流.眨眼间,2019的联赛就已经落下帷幕了,回忆这一年的学习,有许许多多的事情想写下来.趁联赛结果还未出来,赶紧写下这篇文章,以记录我这段时间的学习和生活. "你怎么又 ...
- noi题库(noi.openjudge.cn) 1.7编程基础之字符串T31——T35
T31 字符串P型编码 描述 给定一个完全由数字字符('0','1','2',-,'9')构成的字符串str,请写出str的p型编码串.例如:字符串122344111可被描述为"1个1.2个 ...
- NOI 1.7编程基础之字符串(35题)
01:统计数字字符个数 查看 提交 统计 提问 总时间限制: 1000ms 内存限制: 65536kB 描述 输入一行字符,统计出其中数字字符的个数. 输入 一行字符串,总长度不超过255. 输出 ...
- noi题库(noi.openjudge.cn) 1.7编程基础之字符串T21——T30
T21:单词替换 描述 输入一个字符串,以回车结束(字符串长度<=100).该字符串由若干个单词组成,单词之间用一个空格隔开,所有单词区分大小写.现需要将其中的某个单词替换成另一个单词,并输出替 ...
- 字符串(后缀自动机):NOI 2016 优秀的拆分
[问题描述] 如果一个字符串可以被拆分为 AABB 的形式,其中 A 和 B 是任意非空字符串, 则我们称该字符串的这种拆分是优秀的. 例如,对于字符串 aabaabaa,如果令 A = aab, B ...
- 几何+暴力【p1959】 遗址[NOI导刊2009普及(6)]
题目描述--> P1959 遗址_NOI导刊2009普及(6) 普通方法分析: 因为题目要求是找最大正方形(如果是长方形更麻烦. 讲真,题目不难,耗时间! 根据题目要求,我们要找的是正方形. 我 ...
- noi 题库1.7字符串 第16至20题
16:忽略大小写的字符串比较 一般我们用strcmp可比较两个字符串的大小,比较方法为对两个字符串从前往后逐个字符相比较(按ASCII码值大小比较),直到出现不同的字符或遇到'\0'为止.如果全部字符 ...
随机推荐
- vue 脚手架文件结构及加载过程浅谈
1. 初始化脚手架 1.1 全局安装 @vue/cli npm install -g @vue/cli 1.2 切换到创建项目的目录,执行 vue create projectname 1.3 选 ...
- 【matplotlib基础】--画布
Matplotlib 库是一个用于数据可视化和绘图的 Python 库.它提供了大量的函数和类,可以帮助用户轻松地创建各种类型的图表,包括直方图.箱形图.散点图.饼图.条形图和密度图等. 使用 Mat ...
- 【升职加薪秘籍】我在服务监控方面的实践(8)-elasticsearch 性能监控与分析手段
大家好,我是蓝胖子,之前讲了mysql,redis中间件的监控,今天我们再来看看另一个基础组件elasticsearch,如何对它进行监控,当你思考如何对一个组件进行监控时,四大黄金指标会告诉你答案, ...
- 运用手机运营商二要素Api接口,守护您的账户和隐私,让您安心使用!
随着移动互联网的普及,我们的生活离不开手机,手机成为了我们生活中不可或缺的一部分.但是随着移动支付的普及,手机支付在我们的生活中也变得越来越重要.手机支付是一种方便快捷的支付方式,但是也存在一些安全隐 ...
- PanGu-Coder2:从排序中学习,激发大模型潜力
本文分享自华为云社区<PanGu-Coder2:从排序中学习,激发大模型潜力>,作者: 华为云软件分析Lab . 2022年7月,华为云PaaS技术创新Lab联合华为诺亚方舟语音语义实验室 ...
- ES 2023新特性速解
ES 2023新特性速解 一.新增数组方法 操作数组的方法 Array.prototype.toSorted(compareFn) //返回一个新数组,其中元素按升序排序,而不改变原始数组. Arra ...
- 在阿里云和腾讯云的轻量应用服务器上搭建Hadoop集群
引入 本文在两台2核2g的云服务器上搭建了Hadoop集群,两台云服务器分别是阿里云(hjm)和腾讯云(gyt),集群部署规划如下: hjm gyt HDFS NameNode\SecondaryNa ...
- 工作中常用的一些Git骚操作,一般人我不告诉他。
一.Git提交代码 1 git pull 从服务器上拉取代码 2 git status 查看文件的状态 3 git add . 添加所有文件到暂存区 4 git commit -m "提交的 ...
- .NET Core使用SkiaSharp快速生成二维码( 真正跨平台方案)
前言 在.NET 6之前我们一直是使用QRCoder来生成二维码(QRCoder是一个非常强大的生成二维码的组件,用到了System.Drawing.Common 包),然后从.NET 6开始,当为非 ...
- 2023_10_10_MYSQL_DAY_02_笔记
2023_10_10_MYSQL_DAY_02_笔记 #在 FROM 子句中使用子查询 SELECT a.ename, a.sal, a.deptno, b.salavg FROM emp a, (S ...