将c串从a,b串中删去后求最长公子列  直接暴会超时

#include <cstdio>
#include <cstdlib>
#include <algorithm>
#include <cstring>
using namespace std; char a[1010],b[1010],c[1010];
int dp1[1010][1010],dp2[1010][1010];
int aa[1010],bb[1010];
int main()
{
int t, ca = 1;
scanf("%d",&t);
while(t--)
{
scanf("%s%s%s",a,b,c);
memset(dp1, 0, sizeof(dp1));
memset(dp2, 0 , sizeof(dp2));
int len1 = strlen(a), len2 = strlen(b), len3 = strlen(c);
for(int i = 1; i <= len1; i++)
for(int j = 1; j <= len2; j++)
if(a[i-1] == b[j-1])
dp1[i][j] = dp1[i-1][j-1]+1;
else
dp1[i][j] = max(dp1[i-1][j], dp1[i][j-1]);
for(int i = len1; i >= 1; i--)
for(int j = len2; j >= 1; j--)
if(a[i-1] == b[j-1])
dp2[i][j] = dp2[i+1][j+1]+1;
else
dp2[i][j] = max(dp2[i+1][j], dp2[i][j+1]);
for(int i = 1; i <= len1; i++)
{
int u = 0, j;
for(j = i; j <= len1; j++)
{
if(c[u] == a[j-1]) u++;
if(u == len3) break;
}
if(j <= len1) aa[i] = j;
else aa[i] = 0;
}
for(int i = 1; i <= len2; i++)
{
int u = 0, j;
for(j = i; j <= len2; j++)
{
if(c[u] == b[j-1]) u++;
if(u == len3) break;
}
if(j <= len2) bb[i] = j;
else bb[i] = 0;
}
int _max = 0;
for(int i = 1; i <= len1; i++)
for(int j = 1; j <= len2; j++)
if(aa[i] && bb[j])
_max = max(_max, dp1[i-1][j-1]+dp2[aa[i]+1][bb[j]+1]);
printf("Case #%d: %d\n",ca++,_max+len3);
}
return 0;
}

hdu 4681的更多相关文章

  1. HDU 4681 String 最长公共子序列

    题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=4681 题意: 给你a,b,c三个串,构造一个d串使得d是a,b的子序列,并且c是d的连续子串.求d最大 ...

  2. hdu 4681 最长公共子序列+枚举

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4681 #include<cstdio> #include<cstring> # ...

  3. hdu 4681(枚举+dp)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4681 思路:首先预处理出串C在A,B中的所有的位置,然后从前向后求一次最长公共子序列,从后向前求一次最 ...

  4. Hdu 4681 2013 Multi-University Training Contest 8 String

    带跨越式的LCS,同样是在朴素的LCS上加入一种跨越一段的转移,这样我们要预处理出跨越一段给定串的转移函数. 这个题同样可以正反两边LCS做 呆马: #include <iostream> ...

  5. HDU 4681 String(DP)

    题目链接 枚举A和B中每一段含有C的段,A的前面 后面和B前面后面,求最长公共子序.观察发现,可以预处理最长公共子序. #include <iostream> #include <c ...

  6. hdu 4681 string

    字符串DP 题意:给你三个字符串a,b,c求字符串d的长度. 字符串d满足的要求:是a和b的公共子序列,c是它的子串. 定义dp1[i][j]表示a的第 i 位与b的第 j 位之前相同的子序列长度(包 ...

  7. HDU 4681 string 求最长公共子序列的简单DP+暴力枚举

    先预处理,用求最长公共子序列的DP顺着处理一遍,再逆着处理一遍. 再预处理串a和b中包含串c的子序列,当然,为了使这子序列尽可能短,会以c 串的第一个字符开始 ,c 串的最后一个字符结束 将这些起始位 ...

  8. HDU 4681 String(2013多校8 1006题 DP)

    String Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)Total Subm ...

  9. HDU 4681 STRING dp+暴力。

    题意:不说了很好懂. 这题这么水= =...当时竟然没有勇气暴力搜一下.昨天(好吧前天.)比赛的时候胃疼,看到这题想了一个办法就是对每一个出现最短的C串前后连接然后对这个串求最长公共子序列.其实优化一 ...

随机推荐

  1. sqlserver删除表数据,并让自增长id变为默认值

    例如:TRUNCATE TABLE GaituApp.dbo.Templates

  2. JAVA 实现通过URL下载文件到本地库

    /** * TODO 下载文件到本地 * @author nadim * @date Sep 11, 2015 11:45:31 AM * @param fileUrl 远程地址 * @param f ...

  3. mybatis like 查询

    SELECT * FROM user WHERE name like CONCAT('%',#{name},'%')

  4. Libcurl笔记三

    一,post请求和回报处理 //"host/path?extra" //strHttp=" http://portal.liuhan.com:/web/getConfig ...

  5. linux端口与进程命令

    1 lsof命令 lsof -i:portNum 查出来与该端口相关的所有程序 2 netstat命令: netstat -lnp

  6. java-多线程-join函数

    join()>>不带参数 线程A调用线程B.join,意思就是线程A并入了线程B,当执行完线程B,再去执行线程A后续动作 join(int keepTims)>>带参数,与上面 ...

  7. 使用轻量级Spring @Scheduled注解执行定时任务

    WEB项目中需要加入一个定时执行任务,可以使用Quartz来实现,由于项目就一个定时任务,所以想简单点,不用去配置那些Quartz的配置文件,所以就采用了Spring @Scheduled注解来实现了 ...

  8. JavaScript正则实战

    *:first-child { margin-top: 0 !important; } .markdown-body>*:last-child { margin-bottom: 0 !impor ...

  9. 【SQLite】使用replace替换字段中的字符

    使用replace替换字段中的字符 如:替换production表中的specification字段中的两个空格为一个空格: update production set specification = ...

  10. 利用ApnsPHP包向IOS推送消息

    header('content-type:text/html;charset=utf-8'); require_once 'ApnsPHP/Autoload.php'; require_once 'A ...