问题:在 前一篇文章 最长公共子序列 | 的基础上要求将所有的最长公共子序列打印出来,因为最长公共子序列可能不只一种。

难点:输出一个最长公共子序列并不难,难点在于输出所有的最长公共子序列,我们需要在动态规划表上进行回溯——从C[a][b],即右下角的格子开始判断:

1) 如果格子C[i][j]对应的X[i-1] == Y[j-1],则把这个字符放入 LCS 中,并跳入C[i-1][j-1]中继续进行判断;

2) 如果格子C[i][j]对应的X[i-1] ≠ Y[j-1],则比较C[i-1][j]和C[i][j-1]的值,跳入值较大的格子继续进行判断;

3)直到 i 或 j 小于等于零为止,倒序输出 LCS 。如果出现C[i-1][j]等于C[i][j-1]的情况,说明最长公共子序列有多个,故两边都要进行回溯。

举下面这个例子:x[6]={'B','D','C','A','B','A'}, y[7]={'A','B','C','B','D','A','B'}

通过LCSLength函数我们可以得到C表:如下表所示。

从最右下角我们可以知道最长公共子序列的长度为4,(从0开始编号)从最右下角的元素开始,C[6][7]行列元素对应A!=B,所以不加到 lcs_str(最长公共子序列串),然后考虑C[6][7](行列元素相等)和C[5][7](行列元素相等),而且C[6][7]大小等于C[5][7],所以分别从C[6][7]和C[5][7]开始同样的操作,最后找到三条路径,如上图红线标注,对应为BCAB、BCBA、BDAB。

代码如下:

#include<iostream>
#include <fstream>
#include <cassert>
#include <string>
#include <sstream>
#include <set>
using namespace std;int c[100][100];
int d[100][100];
set<string> setOfLCS;string Reverse(string str)
{int low=0;int high=str.length()-1;while(low<high){char temp=str[low];str[low]=str[high];str[high]=temp;++low;--high;}return str;
}void LCSLength(int m,int n,char *x,char *y)
{int i,j;for(i=1;i<=m;i++)c[i][0]=0;for(i=1;i<=n;i++)c[0][i]=0;for(i=1;i<=m;i++){for(j=1;j<=n;j++){if(x[i]==y[j]){c[i][j]=c[i-1][j-1]+1;d[i][j]=1;}else if(c[i-1][j]>c[i][j-1]){c[i][j]=c[i-1][j];d[i][j]=2;}else{c[i][j]=c[i][j-1];d[i][j]=3;}}}
}void traceBack(int i,int j,char *x,char *y,string lcs_str)
{while(i>0&&j>0){if(x[i]==y[j]){lcs_str.push_back(x[i]);--i;--j;}else{if(c[i-1][j]>c[i][j-1])--i;else if(c[i-1][j]<c[i][j-1])--j;else{traceBack(i-1,j,x,y,lcs_str);traceBack(i,j-1,x,y,lcs_str);return;}}}setOfLCS.insert(Reverse(lcs_str));
}void LCS(int i,int j,char *x)
{if(i==0||j==0)return;if(d[i][j]==1){LCS(i-1,j-1,x);cout<<x[i];}else if(d[i][j]==2)LCS(i-1,j,x);elseLCS(i,j-1,x);
}void readTxt(string file)
{ifstream infile;infile.open(file.data());assert(infile.is_open());string s;getline(infile,s);int n=atoi(s.c_str());int num=1;while(n--){getline(infile,s);istringstream tmp(s);tmp>>s;int a=atoi(s.c_str());tmp>>s;int b=atoi(s.c_str());getline(infile,s);istringstream t1(s);char x[a];char t;for(int i=1;i<=a;i++){t1>>t;x[i]=t;}for(int i=1;i<=a;i++)cout<<x[i]<<" ";cout<<endl;getline(infile,s);istringstream t2(s);char y[b];for(int i=1;i<=b;i++){t2>>t;y[i]=t;}for(int i=1;i<=b;i++)cout<<y[i]<<" ";cout<<endl;cout<<"Case "<<num++<<endl;LCSLength(a,b,x,y);cout<<c[a][b]<<" ";cout<<"LCS(X,Y):";//LCS(a,b,x);cout<<endl;string str;setOfLCS.clear();traceBack(a,b,x,y,str);set<string>::iterator beg = setOfLCS.begin();for( ; beg!=setOfLCS.end(); ++beg)cout << *beg << endl;for(int i=0;i<=b;i++){for(int j=0;j<=a;j++){cout<<c[j][i]<<" ";}cout<<endl;}}infile.close();
}int main()
{readTxt("input.txt");return 0;
}

txt文件输入如下:

运行结果如下:

java实现最长连续子序列_最长公共子序列 ||相关推荐

  1. java实现最长连续子序列_最长公共子序列/最长公共子串 Python/Java实现

    关注我的微信公众号:后端技术漫谈 不定期推送关于后端开发.爬虫.算法题.数据结构方面的原创技术文章,以及生活中的逸闻趣事. 我目前是一名后端开发工程师.主要关注后端开发,数据安全,网络爬虫,物联网,边 ...

  2. 代码随想录训练营day52, 最长递增子序列, 最长连续递增序列, 最长重复子数组

    最长递增子序列 dp[i]的定义, 表示i之前包括i的以nums[i]结尾最长上升子序列的长度 递推: if(nums[i] > nums[j]) dp[i] = max(dp[i], dp[j ...

  3. 求序列最长不下降子序列_最长不下降子序列nlogn算法详解

    今天花了很长时间终于弄懂了这个算法--毕竟找一个好的讲解真的太难了,所以励志我要自己写一个好的讲解QAQ 这篇文章是在懂了这个问题n^2解决方案的基础上学习. 解决的问题:给定一个序列,求最长不下降子 ...

  4. hwd分别是长宽高_衣柜长宽高标准尺寸一般是多少 衣柜怎么保养

    一般的话,我们在市面上购买衣柜的时候会考虑尺寸的问题,因为家里房子的大小不相同,所以选择的尺寸也不一样,如果买的太大了家里就放不下,所以,大家一定要看一下衣柜长宽高的标准尺寸一般是多少,大家可以根据标 ...

  5. java最长单调递增子序列_最长单调递增子序列问题

    最长单调递增子序列问题 题目:设计一个 O( n ^ 2 )复杂度的算法,找出由 n 个数组成的序列的最长单调递增子序列. import java.util.Scanner; public class ...

  6. 最长单调递增子序列_最长递增子序列(动态规划 + 二分搜索)

    题目 给定数组arr,返回arr的最长递增子序列 举例:arr = [2,1,5,3,6,4,8,9,7],返回的最长递增子序列为[1,3,4,8,9] 要求:如果arr的长度为N,请实现时间复杂度为 ...

  7. 回文子序列_计算回文子序列的总数

    回文子序列 Problem statement: 问题陈述: Given a string str, find total number of possible palindromic sub-seq ...

  8. 最长公共子序列算法 java_转【算法之动态规划(三)】动态规划算法之:最长公共子序列 最长公共子串(LCS)字符串相似度算法...

    1.先科普下最长公共子序列 & 最长公共子串的区别: 找两个字符串的最长公共子串,这个子串要求在原字符串中是连续的.而最长公共子序列则并不要求连续. 2.最长公共子串 其实这是一个序贯决策问题 ...

  9. 最长公共子序列(LCS)算法

    一.最长公共字串与最长公共子序列 最长公共子串(Longest Common Substirng) 子串是串的一个连续的部分,子串中字符的位置必须连续. 例如:有两个字符串ABCBDAB 和 BDCA ...

最新文章

  1. Datawhale数据分析教程来了!
  2. 网络编程(发送get和post请求到服务器端,并获取响应)
  3. 04JavaScript中函数也是对象
  4. dot Net Frameworks中常见的设计模式
  5. 无法从套接字读取更多的数据 oracle_小伙面试时被追问数据库优化,面试前如何埋点反杀?
  6. 求最小连续和(洛谷P1614题题解,Java语言描述)
  7. 为什么Alpha多样性的输入数据会是它?
  8. Castle 开发系统文章
  9. 面向对象编程(Object-Oriented Programming)
  10. 中国天花灯市场趋势报告、技术动态创新及市场预测
  11. React Native随笔 2--重要函数
  12. 如何让git小乌龟工具TortoiseGit记住你的账号密码
  13. 卫星定轨理论、GPS信号与卫星星历
  14. 罗马数字转换python_Python实现将罗马数字转换成普通阿拉伯数字的方法
  15. OpenGL中的Alpha测试,深度测试,模板测试,裁减测试 .
  16. Hibernate:cannot simultaneously fetch multiple bags 解决方案
  17. Linux之父、大数据之父确认参加2021世界人工智能大会
  18. 为什么element ui 中表单验证validate验证成功不执行验证成功的逻辑代码
  19. 【C/C++】学前必看知识概览
  20. mysql右表更新左表,mysql优化。左表是25W数据,右表目前小表,但随后是百万,千万,亿级别的表,慢慢增长...

热门文章

  1. GitLab设置中文
  2. XCode 导入头文件不提示解决
  3. [UWP] 用 AudioGraph 来增强 UWP 的音频处理能力——AudioFrameInputNode
  4. JS中8个常见的陷阱
  5. Linux上重启服务的正确命令
  6. C++vector迭代器失效的问题
  7. Linux cut命令
  8. Github的Tom大鸟:我是如何拒绝微软30w的诱惑,专注于Github事业
  9. 10.VMware View 4.6安装与部署-view clint和view for ipad连接测试
  10. 协作是企业管理的重点和难点