【31.58%】【codeforces 682D】Alyona and Strings
time limit per test2 seconds
memory limit per test256 megabytes
inputstandard input
outputstandard output
After returned from forest, Alyona started reading a book. She noticed strings s and t, lengths of which are n and m respectively. As usual, reading bored Alyona and she decided to pay her attention to strings s and t, which she considered very similar.
Alyona has her favourite positive integer k and because she is too small, k does not exceed 10. The girl wants now to choose k disjoint non-empty substrings of string s such that these strings appear as disjoint substrings of string t and in the same order as they do in string s. She is also interested in that their length is maximum possible among all variants.
Formally, Alyona wants to find a sequence of k non-empty strings p1, p2, p3, …, pk satisfying following conditions:
s can be represented as concatenation a1p1a2p2… akpkak + 1, where a1, a2, …, ak + 1 is a sequence of arbitrary strings (some of them may be possibly empty);
t can be represented as concatenation b1p1b2p2… bkpkbk + 1, where b1, b2, …, bk + 1 is a sequence of arbitrary strings (some of them may be possibly empty);
sum of the lengths of strings in sequence is maximum possible.
Please help Alyona solve this complicated problem and find at least the sum of the lengths of the strings in a desired sequence.
A substring of a string is a subsequence of consecutive characters of the string.
Input
In the first line of the input three integers n, m, k (1 ≤ n, m ≤ 1000, 1 ≤ k ≤ 10) are given — the length of the string s, the length of the string t and Alyona’s favourite number respectively.
The second line of the input contains string s, consisting of lowercase English letters.
The third line of the input contains string t, consisting of lowercase English letters.
Output
In the only line print the only non-negative integer — the sum of the lengths of the strings in a desired sequence.
It is guaranteed, that at least one desired sequence exists.
Examples
input
3 2 2
abc
ab
output
2
input
9 12 4
bbaaababb
abbbabbaaaba
output
7
Note
The following image describes the answer for the second sample case:

【题解】
设
f[i][j][k][0]表示s的前i个字母,t的前j个字母里面符合要求的公共序列为k个,且s[i]和t[j]不是第k个公共序列的最后一个元素的最长序列长度;
f[i][j][k][1]表示s的前i个字母,t的前j个字母里面符合要求的公共序列为k个,且s[i]和t[j]是第k个公共序列的最后一个元素的最长序列长度;
边界:
f[i][j][k][0..1]= 0;
f[1][1][1][1] = (s[1]==t[1]?1:0);
根据s[i]是不是等于s[j]。转移一下就可以了。
看代码吧。
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
const int MAXN = 1000 + 20;
const int MAXK = 15;
char s[MAXN],t[MAXN];
int n, m, k;
int dp[MAXN][MAXN][MAXK][2];
int main()
{
//freopen("F:\\rush.txt", "r", stdin);
scanf("%d%d%d", &n, &m, &k);
scanf("%s", s + 1);
scanf("%s", t + 1);
if (s[1] == t[1])
dp[1][1][1][1] = 1;
for (int i = 1;i <= n;i++)
for (int j = 1;j <= m;j++)
for (int l = 1; l <= k; l++)
{
if (i == 1 && j == 1)
continue;
if (i == 1)
{
if (s[1] == t[j])
dp[1][j][1][1] = 1;
dp[1][j][1][0] = dp[1][j - 1][1][0];
if (s[1] == t[j - 1])
dp[1][j][1][0] = max(dp[1][j][1][0],dp[1][j - 1][1][1]);
}
else
if (j == 1)
{
if (s[i] == t[1])
dp[i][1][1][1] = 1;
dp[i][1][1][0] = dp[i-1][1][1][0];
if (s[i-1] == t[1])
dp[i][1][1][0] = max(dp[i][1][1][0], dp[i-1][1][1][1]);
}
else
{
if (s[i] == t[j])
{
dp[i][j][l][1] = dp[i - 1][j - 1][l - 1][0]+1;
if (s[i - 1] == t[j - 1])
{
dp[i][j][l][1] = max(dp[i][j][l][1], dp[i - 1][j - 1][l - 1][1] + 1);
dp[i][j][l][1] = max(dp[i][j][l][1], dp[i - 1][j - 1][l][1] + 1);
}
}
dp[i][j][l][0] = max(dp[i - 1][j][l][0], dp[i][j - 1][l][0]);
dp[i][j][l][0] = max(dp[i][j][l][0], dp[i - 1][j - 1][l][0]);
if (s[i] == t[j - 1])
dp[i][j][l][0] = max(dp[i][j][l][0], dp[i][j - 1][l][1]);
if (s[i - 1] == t[j])
dp[i][j][l][0] = max(dp[i][j][l][0], dp[i - 1][j][l][1]);
if (s[i - 1] == s[j - 1])
dp[i][j][l][0] = max(dp[i][j][l][0], dp[i - 1][j - 1][l][1]);
}
}
printf("%d\n", max(dp[n][m][k][0], dp[n][m][k][1]));
return 0;
}
【31.58%】【codeforces 682D】Alyona and Strings的更多相关文章
- codeforces 682D D. Alyona and Strings(dp)
题目链接: D. Alyona and Strings time limit per test 2 seconds memory limit per test 256 megabytes input ...
- 【31.58%】【codeforces 719B】 Anatoly and Cockroaches
time limit per test 1 second memory limit per test 256 megabytes input standard input output standar ...
- 【 BowWow and the Timetable CodeForces - 1204A 】【思维】
题目链接 可以发现 十进制4 对应 二进制100 十进制16 对应 二进制10000 十进制64 对应 二进制1000000 可以发现每多两个零,4的次幂就增加1. 用string读入题目给定的二进制 ...
- Codeforces 682 D. Alyona and Strings (dp)
题目链接:http://codeforces.com/contest/682/problem/D 给你两个字符串,求两个字符串中顺序k个的相同子串 长度之和.(注意是子串) dp[i][j][k][0 ...
- 【31.72%】【codeforces 604B】More Cowbell
time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...
- 【21.58%】【codeforces 746D】Green and Black Tea
time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...
- 【58.33%】【codeforces 747B】Mammoth's Genome Decoding
time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...
- 【中途相遇法】【STL】BAPC2014 K Key to Knowledge (Codeforces GYM 100526)
题目链接: http://codeforces.com/gym/100526 http://acm.hunnu.edu.cn/online/?action=problem&type=show& ...
- 【codeforces 785D】Anton and School - 2
[题目链接]:http://codeforces.com/contest/785/problem/D [题意] 给你一个长度为n的括号序列; 让你删掉若干个括号之后,整个序列变成前x个括号为左括号,后 ...
随机推荐
- Day2:列表、元组
一.列表 1.定义与访问元素(按索引) #!/usr/bin/env python # -*- coding:utf-8 -*- # Author:Hiuhung Wan list_a = [&quo ...
- LA 3887 - Slim Span 枚举+MST
https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...
- Shiro基础知识08----拦截器介绍(转)
1 拦截器介绍 Shiro使用了与Servlet一样的Filter接口进行扩展:所以如果对Filter不熟悉可以参考<Servlet3.1规范>http://www.iteye.com/b ...
- eclipse 更换国内镜像
大家在用eclipse下载插件,或更新插件的时候,有木有觉得速度贼慢,蜗牛似的速度简直让习惯了4G时代的我们抓狂到底,废话不说,先给大家奉献解决办法 网上找到的国内镜像总结: 1.企业贡献: 搜狐开源 ...
- 可直接复制粘贴的boostrap图标库网址
1:http://fontawesome.dashgame.com/ 2:http://www.kuiyu.net/art-34.html 3:http://www.bootcss.com/p/fon ...
- C++中使用soap toolkit访问webService详解
使用Visual C++开发SOAP客户端应用 使用Visual C++开发SOAP客户端应用 简介 在本篇文章中,我们将讨论如何使用Visual C++开发一个简单的SOAP客户端应用程序,我们还 ...
- 【u250】manhattan
Time Limit: 1 second Memory Limit: 64 MB [问题描述] 混乱的城市已经变得无法控制.大楼随处乱造,城市的布局也是一片混乱.市长决定要结束这种局面,兵器并且想建造 ...
- Pandoc —— 标记语言转换工具(中文乱码问题)
今次毕业设计,来个逼格高的,用 latex 编写.谁曾想,学院首先要收一份 word 版的.辣么多的 latex 公式如何转呀. Pandoc 是由 John MacFarlane 开发的标记语言转换 ...
- 字典(dictionary)的设计
1. 简单接口 struct Dict{ bool has(const string& key); void insert(const string& key, const strin ...
- CentOS 7 下使用yum安装MySQL5.7.20 最简单 图文详解
原文地址:https://blog.csdn.net/z13615480737/article/details/78906598 CentOS7默认数据库是mariadb, 但是 好多用的都是m ...