HDU 1159

  题目大意:给定两个字符串,求他们的最长公共子序列的长度

  解题思路:设字符串 a = "a0,a1,a2,a3...am-1"(长度为m), b = "b0, b1, b2, b3 ... bn-1"(长度为n),

       它们的最长公共子序列为c = "c0, c1, c2, ... ck-1",长度为k,

       dp[i][j]定义为子串 "a0,a1,...,ai-1" 和 子串"b0,b1,...,bj-1"的最长公共子序列,那么dp[m][n]即为所求结果。

       dp[i][j]即a的前i个字母和b的前j个字母的最长公共子序列

       

  接下来说明dp数组的更新过程,

         首先 dp[i][0] 和 dp[0][j]全部初始化为0: 其中有一个子串是空串,最长公共子序列自然为0

       

       若a,b的最后一个字母 am-1 == bn-1,则这个字母一定是c的最后一个字母(对公共子序列有贡献),即ck-1,

         那么 子串 "a0, ... am-2" 与 子串 “b0, ... bn-2”的最长公共子序列为 "c0, ... ck-2"(长度为k-1,加上最后一个字母也就是ck-1长度就是k)

       若 am-1 != bn-1, 有两种情况:

       <1>若am-1 != ck-1(公共子序列的最后一个字母),那么字母am-1对公共子序列就是没有贡献的,

         那么它们的最长公共子序列应该等于子串"a0,a1,a2, ..., am-2" 和 "b0,b1,b2, ..., bn-1"的最长公共子序列,即dp[m-1][n];

       <2>若bn-1 != ck-1, 那么字母bn对公共子序列就是没有贡献的,

         那么它们的最长公共子序列就应该等于子串"a0,a1,a2, ..., am-1" 和 子串 "b0, b1, b2, ... , bn-1"的最长公共子序列,即dp[m][n-1];

       因此考虑以上两种情况,若am-1 != bn-1时,取上面两种情况的最长公共子序列中较大的一个即为am-1 != bn-1时的结果

         即am-1 != bn-1时, 有 dp[m][n] = MAX(dp[m-1][n],  dp[m][n-1]);

  

  初始状态:  dp[0][i] 和 dp[i][0] = 0;

  状态转移方程:

       Ai == Bj时, dp[i][j] = dp[i-1][j-1]+1;

       Ai !=  Bj时, dp[i][j] = MAX(dp[i-1][j], dp[i][j-1]);

/* HDU 1159 Common Subsequence --- 入门dp */
#include <cstdio>
#include <cstring> int dp[][];
char s1[], s2[];
int len1, len2; inline int MAX(int a, int b){
return a > b ? a : b;
} /*
@function: 初始化工作
@param: void
@return: void
*/
void init()
{
len1 = strlen(s1);
len2 = strlen(s2);
for (int i = ; i < len1; ++i){
dp[][i] = ;
} for (int i = ; i < len2; ++i){
dp[i][] = ;
} } int main()
{
#ifdef _LOCAL
freopen("D:\\input.txt", "r", stdin);
#endif /*
定义状态dp[i][j]表示s1前i个字符和s2的前j个字符的最长公共子序列的长度
初始化: dp[i][0] 和 dp[0][j] 全初始化为0 (i <len1, j < len2)
状态转移方程:
s1[i] == s[j]时, dp[i][j] = dp[i-1][j-1]+1
s1[i] != s[j]时, dp[i][j] = MAX(dp[i-1][j], dp[i][j-1])
*/ while (scanf("%s%s", s1, s2) == ){
init(); for (int i = ; i <= len1; ++i){
for (int j = ; j <= len2; ++j){
//详细见状态转移方程
if (s1[i - ] == s2[j - ]){
dp[i][j] = dp[i - ][j - ] + ;
}
else{
dp[i][j] = MAX(dp[i - ][j], dp[i][j - ]);
}
}//for(j)
}//for(i)
printf("%d\n", dp[len1][len2]);
}
return ;
}

  

  相关链接:

  

   

HDU 1159 Common Subsequence的更多相关文章

  1. HDU 1159 Common Subsequence 最长公共子序列

    HDU 1159 Common Subsequence 最长公共子序列 题意 给你两个字符串,求出这两个字符串的最长公共子序列,这里的子序列不一定是连续的,只要满足前后关系就可以. 解题思路 这个当然 ...

  2. HDU 1159 Common Subsequence 公共子序列 DP 水题重温

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1159 Common Subsequence Time Limit: 2000/1000 MS (Jav ...

  3. hdu 1159 Common Subsequence(最长公共子序列)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1159 Common Subsequence Time Limit: 2000/1000 MS (Jav ...

  4. hdu 1159 Common Subsequence(最长公共子序列 DP)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1159 Common Subsequence Time Limit: 2000/1000 MS (Jav ...

  5. HDU 1159 Common Subsequence(裸LCS)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1159 Common Subsequence Time Limit: 2000/1000 MS (Jav ...

  6. HDU 1159 Common Subsequence【dp+最长公共子序列】

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

  7. hdu 1159 Common Subsequence 【LCS 基础入门】

    链接: http://acm.hdu.edu.cn/showproblem.php?pid=1159 http://acm.hust.edu.cn/vjudge/contest/view.action ...

  8. hdu 1159:Common Subsequence(动态规划)

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

  9. hdu 1159 Common Subsequence(LCS最长公共子序列)

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

随机推荐

  1. 企业需要k2来解放孤岛危机

    当我谈孤岛危机时,我谈些什么?你以为我要说的是一款风靡的游戏?那恐怕要让你失望了,今天要谈的是“企业管理体系孤岛”,但更多人甚至都没意识到这是危机. 下面的场景,也许你会觉得似曾相识. 场景一 某制鞋 ...

  2. println与toString()

      public class Test{ public static void main(String[] args) { Mankind mk=new Mankind(); System.out.p ...

  3. Android 应用按两下返回键退出应用程序

    在android应用开发中,有时候应用会用到按两下返回键退出应用的功能,今天介绍一下这个功能,直接上代码: @Override public boolean dispatchKeyEvent(KeyE ...

  4. [转]VS2005 Debug时提示"没有找到MSVCR80D.dll"的解决办法

    总结各种解决方法如下: 原因:(不知道在说啥)由于VS.net 2005 采用了一种新的DLL方案,搞成一个exe还要配有一个manifest文件(一般在嵌入文件里了,所以看不到,不过也可以不嵌入,这 ...

  5. iOS开发中关于nslog的几种流行做法小结

    不管哪种方法,都必须在PCH文件中做下宏定义 DEBUG和RELEASE要分开,RELEASE时log打印要取消 方法一:简单直接,用几行代码搞定,简洁但功能少 #ifdef DEBUG #defin ...

  6. bjui简单了解

    bjui官网:http://demo.b-jui.com/ 其他的我就不是很了解,恶心.

  7. unix shell-01 file

    1 一个文件有三种访问方式: 1.读,可以显示该文件的内容 2.写,删除或者编辑这个文件 3.执行,如果该文件时一个shell脚本或程序 按照文件所针对的用户,用户可以分为三种: 1.文件属主,即该文 ...

  8. LepideMigrator for Documents Step by Step

    blog: http://blog.csdn.net/foxdave A Manager Marketing Operations invite me to review their product, ...

  9. yii2 单页面增删改

    视图层 <style>#tab tr td{    height:40px;    width:100px;}</style><form action="ind ...

  10. PHP中使用的变量

    变量是用于临时的存储值的容器.这些值可以是数字.文本,或者复杂得多的排列组合. 变量在任何编程语言中都居于核心地位,理解它们是使用PHP的关键所在.变量又是指在程序的运行过程中随时可以发生变化的量,是 ...