题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4681

#include<cstdio>
#include<cstring>
#include<cmath>
#include<iostream>
#include<algorithm>
#include<queue>
#include<vector>
using namespace std;
const int maxn = ;
const int INF = 0x3f3f3f; char a[maxn],b[maxn],c[maxn];
int dp1[maxn][maxn];
int dp2[maxn][maxn]; void Lcs1(char* s1,char* s2,int m,int n){
for(int i=;i<=m;i++)
for(int j=;j<=n;j++){
if(s1[i-] == s2[j-]) dp1[i][j] = dp1[i-][j-] + ;
else if(dp1[i-][j]>dp1[i][j-]) dp1[i][j] = dp1[i-][j];
else dp1[i][j] = dp1[i][j-];
}
}
void Lcs2(char* s1,char* s2,int m,int n){
for(int i=m-;i>=;i--)
for(int j=n-;j>=;j--){
if(s1[i+] == s2[j+]) dp2[i][j] = dp2[i+][j+] + ;
else if(dp2[i+][j]>dp2[i][j+]) dp2[i][j] = dp2[i+][j];
else dp2[i][j] = dp2[i][j+];
}
} int main()
{
//freopen("E:\\acm\\input.txt","r",stdin);
int T;
scanf("%d",&T);
for(int t=;t<=T;t++){
memset(dp1,,sizeof(dp1));
memset(dp2,,sizeof(dp2)); scanf("%s%s%s",a,b,c); int lena = strlen(a), lenb = strlen(b), lenc = strlen(c);
Lcs1(a,b,lena,lenb); Lcs2(a,b,lena,lenb); int ans = lenc;
int left1[maxn],right1[maxn];
int lcnt1=,rcnt1=;
int left2[maxn],right2[maxn];
int lcnt2=,rcnt2=;
for(int i=;i<lena;i++){
if(a[i] == c[]){
int cnt = ;
for(int j=i+;j<lena;j++){
if(a[j] == c[cnt]) cnt++;
if(cnt == lenc){
left1[lcnt1++] = i;
right1[rcnt1++] = j;
break;
}
}
} }
for(int i=;i<lenb;i++){
if(b[i] == c[]){
int cnt = ;
for(int j=i+;j<lenb;j++){
if(b[j] == c[cnt]) cnt++;
if(cnt == lenc){
left2[lcnt2++] = i;
right2[rcnt2++] = j;
break;
}
}
}
}
for(int i=;i<lcnt1;i++)
for(int j=;j<lcnt2;j++){
ans = max(ans,dp1[left1[i]][left2[j]] + lenc + dp2[right1[i]][right2[j]] );
}
printf("Case #%d: %d\n",t,ans); }
}

hdu 4681 最长公共子序列+枚举的更多相关文章

  1. HDU 1159 最长公共子序列(n*m)

    Common Subsequence Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

  2. HDU 1159 最长公共子序列

    Common Subsequence Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

  3. HDU - 1503 最长公共子序列记录路径

    题意:先给两个水果的名字然后得出一个最短的序列包含这两个词. 思路:我一开始的思路是先求出最长公共子序列,然后做一些处理将其他的部分输出来:两种水果的字符串和最长公共子序列的字符串这三个字符串做对比, ...

  4. hdu 1503 最长公共子序列

    /* 给两个串a,b.输出一个最短的串(含等于a的子序列且含等于b的子序列) */ #include <iostream> #include <cstdio> #include ...

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

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

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

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

  7. HDU 1159 Common Subsequence:LCS(最长公共子序列)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1159 题意: 求最长公共子序列. 题解: (LCS模板题) 表示状态: dp[i][j] = max ...

  8. HDU 4512 最长公共上升子序列

    各种序列复习: (1)最长上升子序列. 1.这个问题用动态规划就很好解决了,设dp[i]是以第i个数字结尾的上升子序列的最长长度.那么方程可以是dp[i]=max(dp[j]+1).(j<i). ...

  9. HDU 1513 Palindrome(最长公共子序列)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1513 解题报告:给定一个长度为n的字符串,在这个字符串中插入最少的字符使得这个字符串成为回文串,求这个 ...

随机推荐

  1. oracle服务器端-登陆

    由于的的操作系统是windows server版本,所以想装服务器端的server版本,一般的oracle都有'scott'用户,但是貌似服务器端的没有该用户,我用以下方式登陆: sqlplus / ...

  2. 【原】iOS 获取当前和 前后n天的日期

    原文:http://www.cnblogs.com/A--G/p/4759810.html 一.获取当前日期需要调用一个简单的方法:[NSDate date];//获取现在的日期 -(NSString ...

  3. BFC块级格式化上下文简述

    做过页面编写的各位应该对定位不陌生了,这个样式表中的重头戏,也是最难把控的元素之一,今天在这里我们要讲到的就是与浮动与清除浮动相关的定位元素,对于定位有很多种,有绝对定位,还有相对定位,固定定位,静态 ...

  4. node 裁剪图片

    1.前端一般用Jcrop这个jq插件 要返回 x: 图片 x坐标 y: 图片 y坐标 w: 图片 宽度 h: 图片 高度 2.node 实现 var images = require("im ...

  5. J2se中的声音---AudioPlayer

    1 package cn.gp.tools; import java.io.FileInputStream; import java.io.FileNotFoundException; import ...

  6. 一种实现C++反射功能的想法(三)

    如何实现类型名跟类型的对应, 我们很容易想到map, 没错, 就是使用map实现的. std::map<std::string, .....>, 等下, 第二部分该填什么类型, 一个函数指 ...

  7. 『重构--改善既有代码的设计』读书笔记----Substitute Algorithm

    重构可以把复杂的东西分解成一个个简单的小块.但有时候,你必须壮士断腕删掉整个算法,用简单的算法来取代,如果你发现做一件事情可以有更清晰的方式,那你完全有理由用更清晰的方式来解决问题.如果你开始使用程序 ...

  8. .Net用js实现aspx页面删除TextBox输入框的前后空格

    去掉TextBox输入框两头的前后空格:onblur="this.value=this.value.replace(/^\s+|\s+$/g,'');" str为要去除空格的字符串 ...

  9. php学习代码杂记

    16/2/22 字符串连接 (1)连接运算符(“.”):它返回将右参数附加到左参数后面所得的字符串. (2)连接赋值运算符(“.=”):它将右边参数附加到左边的参数后. 相当于JS里面的 += . $ ...

  10. C#,新建的系统服务项目有些机器不能运行

    检查了一下,是权限的问题 右键ProjectInstaller.cs 在设计界面里找到serviceProcessInstaller1右键属性 找到Account属性改为:LocalSystem