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

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

#include<stdio.h>
#include<string.h>
#define maxn 110
char s1[maxn],s2[maxn];
int dp[maxn][maxn],map[maxn][maxn],len1,len2;
void LCS()
{
int i,j;
for(i=;i<=len1;i++)
for(j=;j<=len2;j++)
{
if(s1[i]==s2[j])
{
dp[i][j]=dp[i-][j-]+;
map[i][j]=;
}
else if(dp[i][j-]>dp[i-][j])//标记公共字串的母串,即公共串从哪个串来,
{ //这样回溯的时候就能不改变顺序。
dp[i][j]=dp[i][j-];
map[i][j]=;
}
else
{
dp[i][j]=dp[i-][j];
map[i][j]=-;
}
}
}
void print(int i,int j)
{
if(i==&&j==)return;
if(i==){
print(i,j-);printf("%c",s2[j]);
}
else if(j==){
print(i-,j);printf("%c",s1[i]);
}
else if(map[i][j]==){//是相同的字母 只输出一次
print(i-,j-);printf("%c",s1[i]);
}
else if(map[i][j]>){
print(i,j-);printf("%c",s2[j]);
}
else {
print(i-,j);printf("%c",s1[i]);
}
}
int main()
{
int i,j;
while(scanf("%s%s",s1,s2)!=EOF)
{
memset(dp,,sizeof(dp));
memset(map,,sizeof(map)); len1=strlen(s1);
len2=strlen(s2); /*for(i=0;i<=len1;i++)//这里主要为了防止出现负值,在i或j为0时使用
map[i][0]=-1;
for(i=0;i<=len2;i++)
map[0][i]=1;*/ for(i=len1;i>;i--)
s1[i]=s1[i-];
for(i=len2;i>;i--)
s2[i]=s2[i-];
LCS();//求一次公共字串 标记相同的串 相同串只需要输出一次
print(len1,len2);
puts("");
}
}

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. 关于开启Eureka安全Security认证后,客户端死活注册不上的问题

    遇到一个问题"开启Eureka服务端的安全认证后,客户端死活注册不到Eureka上",已经尝试了以下办法,完全搞不定... 客户端出错的版本: spring-boot:2.0.3. ...

  2. pixhawk 常见问题 持续更新

    红灯蓝灯闪,初始化中,请稍等 黄灯双闪,错误,系统拒绝解锁 黄灯闪,遥控器关闭 黄灯快速闪且滴滴响,电池保护激活 蓝灯... 未见过.... 绿灯闪: 已加锁,GPS锁定已获得. 准备解锁. 从加锁状 ...

  3. js判断两个对象是否相等

    function isObjectValueEqual(a, b) { if(typeof a == 'number' && typeof b == 'number'){ return ...

  4. java 中Vector的使用详解

    Vector 可实现自动增长的对象数组. java.util.vector提供了向量类(vector)以实现类似动态数组的功能.在Java语言中没有指针的概念,但如果正确灵活地使用指针又确实可以大大提 ...

  5. pycharm2018激活

    pyCharm最新2018最新激活码 选择 Activate new license with License server (用license server 激活) 在 License sever ...

  6. Ubuntu中安装gdal python版本

    安装过程: python包是从C++包中编译出来的,所以需要将源码下载进行编译安装 1.GDAL中的矢量数据处理OGR依赖于Geos,在安装GDAL之前要安装Geos Geos的下载地址:http:/ ...

  7. Vue-cli3.x中使用Axios发送跨域请求的配置方法

    Vue-cli3.x中使用Axios发送跨域请求的配置方法 安装axios npm i axios -s main.js中引入 import axios from 'axios' //将axios挂载 ...

  8. java swing多线程

    比如一个爬虫 在界面上显示当前时间,每秒都刷新一次用来判断软件是不是卡死 在爬取程序运行的时候,界面可能会卡死 那这就要把爬取程序放在另一个线程里边 同时,也可以把rtc放在另一个线程里边 具体代码, ...

  9. mysql8.0 的坑 hibernate连接配置坑

    https://blog.csdn.net/qq_36448800/article/details/81180881 这篇文章对于连接配置说的是对的,也比较全面

  10. Python之路,Day3- Python基础(转载Alex)

    本节内容 1. 函数基本语法及特性 2. 参数与局部变量 3. 返回值 嵌套函数 4.递归 5.匿名函数 6.函数式编程介绍 7.高阶函数 8.内置函数 温故知新 1. 集合 主要作用: 去重 关系测 ...