NOIP2015 子串
#149. 【NOIP2015】子串
有两个仅包含小写英文字母的字符串 AA 和 BB。
现在要从字符串 AA 中取出 kk 个互不重叠的非空子串,然后把这 kk 个子串按照其在字符串 AA 中出现的顺序依次连接起来得到一个新的字符串。请问有多少种方案可以使得这个新串与字符串 BB 相等?
注意:子串取出的位置不同也认为是不同的方案。
输入格式
第一行是三个正整数 n,m,kn,m,k,分别表示字符串 AA 的长度,字符串 BB 的长度,以及问题描述中所提到的 kk,每两个整数之间用一个空格隔开。
第二行包含一个长度为 nn 的字符串,表示字符串 AA。
第三行包含一个长度为 mm 的字符串,表示字符串 BB。
输出格式
输出共一行,包含一个整数,表示所求方案数。
由于答案可能很大,所以这里要求输出答案对 10000000071000000007 取模的结果。
样例一
input
6 3 1
aabaab
aab
output
2
样例二
input
6 3 2
aabaab
aab
output
7
样例三
input
6 3 3
aabaab
aab
output
7
explanation
所有合法方案如下:(加下划线的部分表示取出的子串)
样例一:aab aab / aab aab
样例二:a ab aab / a aba ab / a a ba ab / aab a ab / aa b aab / aa baa b / aab aa b
样例三:a a b aab / a a baa b / a ab a a b / a aba a b / a a b a a b / a a ba a b / aab a a b
限制与约定
测试点编号 | nn的规模 | mm的规模 | kk的规模 |
---|---|---|---|
1 | n≤500n≤500 | m≤50m≤50 | k=1k=1 |
2 | k=2k=2 | ||
3 | |||
4 | k=mk=m | ||
5 | |||
6 | k≤mk≤m | ||
7 | |||
8 | n≤1000n≤1000 | m≤100m≤100 | |
9 | |||
10 | m≤200m≤200 |
时间限制:1s1s
空间限制:128MB128MB
题解:
//参考blog.sengxian.com
※先定义:s[i][j][k]为字符串A第i-1位对应字符串B第j-1位所达到的种类数,f[i][j][k]为A的i-1位和B的j-1位正好配对时所达到的种类数。
※转移方程1:那么很容易得到:s[i][j][k]=s[i-1][j][k]+f[i][j][k],即当前阶段的种类数=上一阶段未使用i-1位的种类数+使用i-1位的种类数。
※转移方程2:那么现在考虑怎样转移f[i][j][k],要分两种情况。
1.当A(i-1) ≠ B(j-i)时,很明显f[i][j][k]=0
2.当A(i-1) = B(j-i)时,就又回到选与不选的问题上来了。所以,又分两种情况,一是直接和i-1与j-1配对的情况并未同一个子串,二是不并,新成立一个子串
可知:
0 (A(i-1) ≠ B(j-i))
f[i][j][k]=
f[i-1][j-1][k]+s[i-1][j-1][k-1] (A(i-1) = B(j-i))
#104939 | #149. 【NOIP2015】子串 | ksq2013 | 100 | 112ms | 4100kb | C++ | 565b | 2016-10-28 17:16:59 |
程序如下:
#include<cstdio>
#include<cstring>
#include<iostream>
#define MXN 1100
#define md 1000000007
#define fx(x,a,b) for(x=a;x<=b;x++)
#define fy(x,a,b) for(x=a;x>=b;x--)
using namespace std;
int N,M,K,i,j,k,s[MXN][MXN],f[MXN][MXN];
char s1[MXN],s2[MXN];
int main()
{
scanf("%d%d%d",&N,&M,&K);
getchar();
gets(s1);
gets(s2);
s[][]=;
fx(i,,N)fy(j,M,)
if(s1[i-]==s2[j-])
fy(k,min(K,j),)
f[j][k]=(s[j-][k-]+f[j-][k])%md,s[j][k]=(s[j][k]+f[j][k])%md;
else fill(f[j],f[j]+min(K,j)+,);
printf("%d\n",s[M][K]);
return ;
}
NOIP2015 子串的更多相关文章
- NOIP2015子串[序列DP]
题目背景 无 题目描述 有两个仅包含小写英文字母的字符串 A 和 B.现在要从字符串 A 中取出 k 个互不重 叠的非空子串,然后把这 k 个子串按照其在字符串 A 中出现的顺序依次连接起来得到一 个 ...
- LOJ2424 NOIP2015 子串 【DP】*
LOJ2424 NOIP2015 子串 LINK 题目大意是给你两个序列,在a序列中选出k段不重叠的子串组成b序列,问方案数 首先我们不考虑相邻的两段,把所有相邻段当成一段进行计算 然后设dpi,j, ...
- [NOIP2015] 子串(dp)
题目描述 有两个仅包含小写英文字母的字符串 A 和 B.现在要从字符串 A 中取出 k 个互不重叠的非空子串,然后把这 k 个子串按照其在字符串 A 中出现的顺序依次连接起来得到一 个新的字符串,请问 ...
- [vijos1982][NOIP2015]子串
Description 有两个仅包含小写英文字母的字符串和.现在要从字符串中取出个互不重叠的非空子串,然后把这个子串按照其在字符串中出现的顺序依次连接起来得到一个新的字符串,请问有多少种方案可以使得这 ...
- 【uoj149】 NOIP2015—子串
http://uoj.ac/problem/149 (题目链接) 题意 给出两个字符串A.B,问从A中取出k个互不重叠的子串按顺序组成B的方案数. Solution 一看这种题目就是字符串dp,字符串 ...
- [NOIP2015] 子串substring 题解
[题目描述] 有两个仅包含小写英文字母的字符串A和B.现在要从字符串A中取出k个互不重叠的非空子串,然后把这k个子串按照其在字符串A中出现的顺序依次连接起来得到一个新的字符串,请问有多少种方案可以使得 ...
- NOIP2015 子串 (DP+优化)
子串 (substring.cpp/c/pas) [问题描述] 有两个仅包含小写英文字母的字符串 A 和 B.现在要从字符串 A 中取出 k 个 互不重 叠 的非空子串,然后把这 k 个子串按照其在字 ...
- [DP][NOIP2015]子串
子串 题目描述 有两个仅包含小写英文字母的字符串 A 和 B. 现在要从字符串 A 中取出 k 个 互不重叠 的非空子串, 然后把这 k 个子串按照其在字符串 A 中出现的顺序依次连接起来得到一个新的 ...
- [NOIP2015]子串 题解
题目描述 有两个仅包含小写英文字母的字符串A和B. 现在要从字符串A中取出k个互不重叠的非空子串,然后把这 k 个子串按照其在字符串 A 中出现的顺序依次连接起来得到一个新的字符串,请问有多少种方案可 ...
随机推荐
- 通过GP加载卫星云图-雷达图-降雨预报图
# ---------------------------------------------------------------------------# MeteorologicalImageLo ...
- 关于web软件信息安全问题防护资料的整理(二)
想要做好软件的安全防护,首先就得了解web系统的安全威胁,那么web系统都存在哪些威胁呢? 应用层攻击.网络层攻击和混合攻击. 传统被动.单点以及彼此孤立的防护手段已不能应对越来越严峻的安全威胁. 改 ...
- Atitit.木马病毒强制强行关闭360 360tray.exe的方法
Atitit.木马病毒强制强行关闭360 360tray.exe的方法 1. taskkill /im 进程名称1 2. 用 wmic process where name="进程名称&qu ...
- Sharepoint学习笔记—习题系列--70-576习题解析 -(Q66-Q68)
Question 66 You are designing an application that will use a timer job that will run each night to s ...
- Unable to execute dex: Multiple dex files define(错误分析)
eclipse工程包名与依靠的代码库包名不能冲突,否则运行程序程序会出错 错误提示:
- Android SharedPreference的使用
在<Android 在内部存储读写文件>一文中,谈到了登录用户名和密码的方法,通过读取内存文件来实现,但是会出现问题,因为登录名和密码的形式通过username##password的形式, ...
- 【原】iOS:一种直接修改frame的某个属性的方法
在iOS中view的frame属性使用地太频繁了,尤其是调UI的时候.我们知道,正常情况下我们无法对frame的某个属性(x,y,width,height等)进行单独修改,比如: someView.f ...
- Hello BIEE
这篇文章提供了一个Hello World式的例子,讲述如何创建一个最简单的BIEE资料库.本文使用的示例数据可以在从此链接下载:http://www.zw1840.com . 目录 创建资料库 创 ...
- 数据库模型设计——历史与版本设计
在企业数据库设计中,经常会遇到一个需求,就是希望把操作之前的数据保留下来,能够看到操作之前是什么数据,操作之后是什么数据.对于这种需求,我们可以使用保留历史数据或者使用版本来实现. 为了能够保留历史数 ...
- 在JSP动态网页中输出九九乘法表
<% StringBuffer sb = new StringBuffer(); ; i <= ; i++){ ; j <= i; j++){ sb.append(j + " ...