当前位置: 首页 > news >正文

最长子序列问题(LCS)--动态规划解法

题目描述:

如果Z既是X的子序列,又是Y的子序列,则称Z为X和Y的公共子序列。

如果给定X、Y,求出Y及其长度。

示例:

输入

ABCPDSFJGODIHJOFDIUSHGD
OSDIHGKODGHBLKSJBHKAGHI

输出

SDIHODSHG
9

分析:

c[i][j]表示X从0到i与Y从0到j之间公共子序列的长度。

代码 :

//最长子序列问题,不是最长字串问题
#include<iostream>
#include<stack>
using namespace std;const int N = 1000;
int dp[N][N] = { 0 };
int path[N][N];
int  main()
{string a, b;cin >> a;cin >> b;int lena = a.size();int lenb = b.size();for (int i = 0; i <lena-1; i++){for (int j = 0; j <lenb-1; j++){if (a[i] == b[j]){dp[i+1][j+1] = dp[i][j] + 1;path[i + 1][j + 1] = 1;}else if (dp[i][j + 1] >= dp[i + 1][j]){dp[i + 1][j + 1] = dp[i][j + 1];path[i + 1][j + 1] = 2;}else{dp[i + 1][j + 1] = dp[i+1][j];path[i + 1][j + 1] = 3;}}}cout << "dp数组为:" << endl;for (int i = 0; i < lena; i++){for (int j = 0; j < lenb; j++){cout << dp[i][j] << ' ';}cout << endl;}cout << "最长子序列数为:" << dp[lena - 1][lenb - 1] << endl;//存放最长子序列stack<char>same;for (int i = lena - 1, j = lenb - 1; i >= 0 && j >= 0;){if (path[i][j] == 1){i--;j--;same.push(a[i]);}else if (path[i][j] == 2){i--;}else{j--;}}cout << "最长子序列为";while (!same.empty()){cout << same.top();same.pop();}cout << endl;system("pause");return 0;}

http://www.lryc.cn/news/256176.html

相关文章:

  • 实时流式计算 kafkaStream
  • 西南科技大学模拟电子技术实验七(集成运算放大器的非线性应用)预习报告
  • Ubuntu与Windows通讯传输文件(FTP服务器版)(没用的方法,无法施行)
  • 2024年AI视频识别技术的6大发展趋势预测
  • 一篇文章了解JDK的前世今生
  • Redisson出现问题总结
  • 领域驱动架构(DDD)建模
  • PostgreSQL从小白到高手教程 - 第38讲:数据库备份
  • OpenGL ES eglCreatePbufferSurface() 和 eglCreateWindowSurface() 的对比和使用
  • python之马尔科夫链(Markov Chain)
  • 数据库管理-第123期 Oracle相关两个参数(202301205)
  • 掌握vue中国际化使用及配置
  • Ubuntu编译文件安装SNMP服务
  • 3D Web可视化平台助力Aras开发PLM系统:提供数据访问、可视化和发布功能
  • Graphpad Prism10.1.0 安装教程 (含Win/Mac版)
  • 【动态规划】路径问题_不同路径_C++
  • Python并发-线程和进程
  • 微信小程序适配方案:rpx(responsive pixel响应式像素单位)
  • vue2 echarts饼状图,柱状图,折线图,简单封装以及使用
  • Linux信息收集
  • 三种定时任务总结
  • [足式机器人]Part2 Dr. CAN学习笔记-数学基础Ch0-6复数Complex Number
  • 使用 MITRE ATTCK® 框架缓解网络安全威胁
  • 从零构建属于自己的GPT系列4:模型训练3(训练过程解读、序列填充函数、损失计算函数、评价函数、代码逐行解读)
  • 光学遥感显著目标检测初探笔记总结
  • HttpComponents: 领域对象的设计
  • 使用wire重构商品微服务
  • 大三上实训内容
  • IOT安全学习路标
  • java中线程的状态是如何转换的?