HDU 5282:Senior's String
Senior's String
学姐姐非常喜欢字符串,所以学弟送给了她两个字符串作为礼物。 两个字符串分别为X,Y。她非常开心,但在开心之余她还想考考学弟。 她定义L为X与Y的最长公共子序列的长度(子序列在字符串内不一定连续,一个长度为L的字符串有2L个子序列,包括空子序列)。 现在学姐姐取出了X的所有长度为L的子序列,并要求学弟回答在这些子序列中,有多少个是Y的子序列。 因为答案可能很大,所以学弟只需要回答最终答案模109+7。
第一行包含一个整数T,表示测试数据组数。 对于每组测试数据: 第一行包含一个非空字符串X。 第二行包含一个非空字符串Y。 字符串由小写英文字母构成。 1≤|X|,|Y|≤1000, |X|表示X的长度。
对于每组测试数据输出一个整数,表示对应的答案。
2
a
b
aa
ab
1
2
题解:
首先我们用O(n2)的动态规划算法处理出dp数组,dp[i][j]表示X串的前i个字符和Y串的前j个字符的最长公共子序列的长度,在这个基础上我们再进行一个动态规划。用f[i][j]表示在X串的前i个字符中,有多少个长度为dp[i][j]的子序列在Y的前j个字符中也出现了。转移:若dp[i−1][j]==dp[i][j],则f[i][j]+=f[i−1][j],表示i这个字符不选;再考虑选i这个字符,找到Y串前j个字符中最靠后的与X[i]匹配的字符的位置,设为p,若dp[i−1][p−1]+1==dp[i][j],则f[i][j]+=f[i−1][p−1]。最终的答案即为f[n][m]。复杂度O(n2)。
看着题解给的思路,想不明白。
然后又用到了两重动态规划,第一个很好理解,第二个其实就是对于每一个字符串x的字符,看它在不在长度为L“相等”的子序列里面,不在的话是第一种,在的话(即与x字符串之前的字符重复)是第二种。
代码:
#include <iostream>
#include <string>
#include <cstring>
#include <algorithm>
#include <cmath>
using namespace std; const int mod=1000000007; int dp[1003][1003];
int f[1007][1007];
int meet[1007][27]; string x,y; int main()
{
int Test,m,n,i,j;
cin>>Test; while(Test--)
{
cin>>x>>y; m=x.length();
n=y.length(); memset(dp,0,sizeof(dp)); for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
{
if(x[i] == y[j])
{
dp[i+1][j+1] = dp[i][j]+1;
}
else
{
dp[i+1][j+1] = max(dp[i][j+1],dp[i+1][j]);
}
}
}
memset(f,0,sizeof(f));
memset(meet,0,sizeof(meet)); for(i=0;i<n;i++)
{
for(j=0;j<26;j++)
{
meet[i+1][j] = meet[i][j];
} meet[i+1][y[i]-'a']=i+1;
} for(i=0;i<=m;i++)
{
for(j=0;j<=n;j++)
{
if(dp[i][j]==0)
{
f[i][j]=1;
continue;
}
if(dp[i-1][j]==dp[i][j])
{
(f[i][j]=f[i-1][j])%=mod;
}
int p= meet[j][x[i-1]-'a']; if(dp[i-1][p-1]+1==dp[i][j])(f[i][j]+=f[i-1][p-1])%=mod;
}
}
cout<<f[m][n]%mod<<endl;
}
return 0;
}
f[i][j]+=f[i−1][j]
f[i][j]+=ff[i][j]+=f[i−1][j]
f[i][j]+=f[i−1][j]
f[i][j]+=f[i−1][j]
f[i][j]+=f[i−1][j]
f[i][j]+=f[i−1][j]
f[i][j]+=f[i−1][j]
版权声明:本文为博主原创文章,未经博主允许不得转载。
HDU 5282:Senior's String的更多相关文章
- HDU - 6166:Senior Pan(顶点集合最短路&二进制分组)
Senior Pan fails in his discrete math exam again. So he asks Master ZKC to give him graph theory pro ...
- HDU - 5421:Victor and String (回文树,支持首尾插入新字符)
Sample Input 6 1 a 1 b 2 a 2 c 3 4 8 1 a 2 a 2 a 1 a 3 1 b 3 4 Sample Output 4 5 4 5 11 题意:多组输入,开始字符 ...
- hdu 5282 Senior's String 两次dp
题链:http://acm.hdu.edu.cn/showproblem.php?pid=5282 Senior's String Time Limit: 2000/1000 MS (Java/Oth ...
- HDU 4287 Intelligent IME(string,map,stl,make_pair)
题目 转载来的,有些stl和string的函数蛮好的: //numx[i]=string(sx); //把char[]类型转换成string类型 // mat.insert(make_pair(num ...
- 提高你的Java代码质量吧:正确使用String、StringBuffer、StringBuilder
一.建议 CharSequence接口有三个实现类与字符串相关:String.StringBuffer.StringBuilder,虽然它们都与字符串相关,但是其处理机制不同. 根据不同的场景,建议 ...
- 转换String三种方式比较:toString()、String.valueOf()、(String)
简单介绍: 1.toString,需要保证调用这个方法的类.方法.变量不为null,否则会报空指针. 2.String.valueOf.这个方法在使用的时候是有些特殊的.一般情况下,如果是确定类型的n ...
- 分享:SringBuffer与String的区别
·作为Java中最为基础的部分,在Java的学习过程中,就一定会学习到字符串,其中String类作为字符串.并且在Java所有的程序中是使用字符串都是使用String类去实现. 两者存在一定的通性,都 ...
- C++:如何删除string对象的末尾非数字字符
功能实现: 现有一个string对象包含数字字符以及非数字字符,实现删除string对象的末尾非数字字符. 实例: 输入为"0 1 1 2 3 " 输出为"0 1 ...
- MySQL:1366 - Incorrect string value错误解决办法
今天使用navicat向MySQL中插入中文时,报错: - Incorrect string value:... 在我自己数据库设计之初,没有设计好字符编码格式的问题. 使用如下语句解决: alter ...
随机推荐
- 学会使用Google hacking
https://klionsec.github.io/2014/12/14/search-hacking/ 熟练利用Google hacking 来辅助我们快速渗透 http://www.sec-re ...
- 《O’Reilly精品图书系列共21册》azw3
套装书目: <机器学习:实用案例解析> <利用Python进行数据分析> <社交网站的数据挖掘与分析(原书第2版)> <社会网络分析:方法与实践> &l ...
- Java中很少用的CopyOnWriteArrayList
类注释 /** * A thread-safe variant of {@link java.util.ArrayList} in which all mutative * operations ({ ...
- [STL]string类型的getline函数
3.cin.getline() 实际是cin.getline(接收字符串到m,接收个数n,结束字符).接收一个字符串,可以接收空格等,最后一个字符为‘\0’.结束符可以通过设置第三个参数自己设置,默认 ...
- NO19 优化Linux系统--重要开机自启动服务--关闭自启动项
**如何优化Linux系统: 1 不用root,添加普通用户,通过sudo授权管理.2 更改默认的远程连接SSH服务端口及禁止root用户远程连接.3 定时自动更新服务器时间.4 配置 ...
- python2学习------基础语法2(函数)
1.函数 # 无参数函数 def loopTest2(): a=1; while a<40: print a; a=a+1; if a==35: continue; else: print 'o ...
- Ternsorflow 学习:004-MNIST入门 构建模型
Softmax回归介绍 我们知道MNIST的每一张图片都表示一个数字,从0到9.我们希望得到给定图片代表每个数字的概率.比如说,我们的模型可能推测一张包含9的图片代表数字9的概率是80%但是判断它是8 ...
- 第3节 sqoop:7、通过java代码远程连接linux执行shell命令
数据库的数据同步软件sqoop 数据同步 关系型数据库到大数据平台 任务:sqoop 是批量导入数据太慢,如何做到实时的数据同步 实时的数据同步工具: canal 阿里开源的一个数据库数据实时同步的软 ...
- loadBeanDefinitions方法源码跟踪(一)
看这篇文章之前可以先了解之前的跟踪流程,https://www.jianshu.com/p/4934233f0ead 代码过宽,可以shift + 鼠标滚轮 左右滑动查看 AbstractBeanDe ...
- Android拷贝工程不覆盖原工程的配置方法
http://www.2cto.com/kf/201203/125131.html 在Eclipse中改包名的时候选择refactor-->rename,勾选Rename subpackages ...