题意:如果有相同的字母,这些字母只输出一次。其余的都输出。

先做一次LCS,标记相同的字母,然后回溯输出。

  1. #include<stdio.h>
  2. #include<string.h>
  3. #define maxn 110
  4. char s1[maxn],s2[maxn];
  5. int dp[maxn][maxn],map[maxn][maxn],len1,len2;
  6. void LCS()
  7. {
  8. int i,j;
  9. for(i=;i<=len1;i++)
  10. for(j=;j<=len2;j++)
  11. {
  12. if(s1[i]==s2[j])
  13. {
  14. dp[i][j]=dp[i-][j-]+;
  15. map[i][j]=;
  16. }
  17. else if(dp[i][j-]>dp[i-][j])//标记公共字串的母串,即公共串从哪个串来,
  18. { //这样回溯的时候就能不改变顺序。
  19. dp[i][j]=dp[i][j-];
  20. map[i][j]=;
  21. }
  22. else
  23. {
  24. dp[i][j]=dp[i-][j];
  25. map[i][j]=-;
  26. }
  27. }
  28. }
  29. void print(int i,int j)
  30. {
  31. if(i==&&j==)return;
  32. if(i==){
  33. print(i,j-);printf("%c",s2[j]);
  34. }
  35. else if(j==){
  36. print(i-,j);printf("%c",s1[i]);
  37. }
  38. else if(map[i][j]==){//是相同的字母 只输出一次
  39. print(i-,j-);printf("%c",s1[i]);
  40. }
  41. else if(map[i][j]>){
  42. print(i,j-);printf("%c",s2[j]);
  43. }
  44. else {
  45. print(i-,j);printf("%c",s1[i]);
  46. }
  47. }
  48. int main()
  49. {
  50. int i,j;
  51. while(scanf("%s%s",s1,s2)!=EOF)
  52. {
  53. memset(dp,,sizeof(dp));
  54. memset(map,,sizeof(map));
  55.  
  56. len1=strlen(s1);
  57. len2=strlen(s2);
  58.  
  59. /*for(i=0;i<=len1;i++)//这里主要为了防止出现负值,在i或j为0时使用
  60. map[i][0]=-1;
  61. for(i=0;i<=len2;i++)
  62. map[0][i]=1;*/
  63.  
  64. for(i=len1;i>;i--)
  65. s1[i]=s1[i-];
  66. for(i=len2;i>;i--)
  67. s2[i]=s2[i-];
  68. LCS();//求一次公共字串 标记相同的串 相同串只需要输出一次
  69. print(len1,len2);
  70. puts("");
  71. }
  72. }

LCS的题目基本上就是一个类型加上变换。dp[i][j]表示到目前为止的公共最大长度。

如果 s[i]==s[j] dp[i][j]可以从dp[i-1][j-1]+1得到;

不然的话就是max(dp[i-1][j],dp[i][j-1]);
因为从一开始就是最优的,所以dp[i-1][j],dp[i][j-1]放了当前不满足条件的时候的前几个以求出的值。

hdu1503 LCS的更多相关文章

  1. HDU1503(LCS,记录路径)

    Advanced Fruits Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)T ...

  2. HDU1503:Advanced Fruits(LCS)

    Problem Description The company "21st Century Fruits" has specialized in creating new sort ...

  3. 我的第一篇博客----LCS学习笔记

    LCS引论 在这篇博文中,博主要给大家讲一个算法----最长公共子序列(LCS)算法.我最初接触这个算法是在高中学信息学竞赛的时候.那时候花了好长时间理解这个算法.老师经常说,这种算法是母算法,即从这 ...

  4. 动态规划之最长公共子序列(LCS)

    转自:http://segmentfault.com/blog/exploring/ LCS 问题描述 定义: 一个数列 S,如果分别是两个或多个已知数列的子序列,且是所有符合此条件序列中最长的,则 ...

  5. 动态规划求最长公共子序列(Longest Common Subsequence, LCS)

    1. 问题描述 子串应该比较好理解,至于什么是子序列,这里给出一个例子:有两个母串 cnblogs belong 比如序列bo, bg, lg在母串cnblogs与belong中都出现过并且出现顺序与 ...

  6. Hackerrank11 LCS Returns 枚举+LCS

    Given two strings,  a and , b find and print the total number of ways to insert a character at any p ...

  7. UVA 11404 Palindromic Subsequence[DP LCS 打印]

    UVA - 11404 Palindromic Subsequence 题意:一个字符串,删去0个或多个字符,输出字典序最小且最长的回文字符串 不要求路径区间DP都可以做 然而要字典序最小 倒过来求L ...

  8. 删除部分字符使其变成回文串问题——最长公共子序列(LCS)问题

    先要搞明白:最长公共子串和最长公共子序列的区别.    最长公共子串(Longest Common Substirng):连续 最长公共子序列(Longest Common Subsequence,L ...

  9. 最大公共字串LCS问题(阿里巴巴)

    给定两个串,均由最小字母组成.求这两个串的最大公共字串LCS(Longest Common Substring). 使用动态规划解决. #include <iostream> #inclu ...

随机推荐

  1. String和StringBuffer的区别;字符串的一些基本方法

    String 和 StringBuffer区别 字符串广泛应用 在Java 编程中,在 Java 中字符串属于对象,Java 提供了 String 类来创建和操作字符串. 需要注意的是,String的 ...

  2. java求1000以内的水仙花数

    水仙花数是指一个 n 位数 ( n>=3 ),它的每个位上的数字的 n 次幂之和等于它本身.(例如:1^3 + 5^3 + 3^3 = 153) 三位的水仙花数共有4个,分别为:153.370. ...

  3. Linux下ps -ef和ps aux的区别及格式详解-转

    原文:https://www.linuxidc.com/Linux/2016-07/133515.htm Linux下显示系统进程的命令ps,最常用的有ps -ef 和ps aux.这两个到底有什么区 ...

  4. KOA 学习(八) koa-bodyparser

    此控件支持Josn,form,text类型 用法 var Koa = require('koa'); var bodyParser = require('koa-bodyparser'); var a ...

  5. TZOJ 4024 游戏人生之梦幻西游(连续子段和绝对值最小)

    塔神酷爱玩梦幻西游这款游戏,这款游戏以著名的章回小说<西游记>故事为背景,透过Q版的人物,营造出浪漫的网络游戏风格.塔神以追求天下无敌为目标,从一个默默无闻的菜鸟,打拼到了登峰造极的大师, ...

  6. vim编辑器操作①

    Linux文本编辑器: 行编辑器:sed 全屏编辑器:nano,vi/vim 本文主要介绍说明vim编辑器的相关使用: 其有三种模式,即: 编辑模式(默认模式).插入模式(输入模式).末行模式(内置的 ...

  7. TZ_16ES6学习总结

    1.块级作用域的引入 在ES6之前,js只有全局作用域和函数作用域,ES6中let关键字为其引入了块级作用域. { var a = 5; let b = 6; } console.log(a); // ...

  8. 移动端H5适配流程

    (一) 由于手机生产商越来越多,不同手机的硬件尺寸又不尽相同,这就给我们的设计适配造成很大困扰.但我们可以围绕从基准分辨率设计,上下进行兼容适配的原则来进行快捷操作.以IOS阵营为例: 图注:移动适配 ...

  9. php解决高并发(文件锁)

    文件锁分为两种方式: [一].阻塞模式:(如果其他进程已经加锁文件,当前进程会一直等其他进程解锁文件后继续执行) <?php //连接数据库 $con=mysqli_connect(" ...

  10. java.lang.UnsupportedClassVersionError: com/gargoylesoftware/htmlunit/WebClient : Unsupported major.minor version 52.0 (unable to load class com.gargoylesoftware.htmlunit.WebClient)

    java.lang.UnsupportedClassVersionError: com/gargoylesoftware/htmlunit/WebClient : Unsupported major. ...