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

每日OJ题_两个数组dp①_力扣1143. 最长公共子序列

目录

力扣1143. 最长公共子序列

解析代码


力扣1143. 最长公共子序列

1143. 最长公共子序列

难度 中等

给定两个字符串 text1 和 text2,返回这两个字符串的最长 公共子序列 的长度。如果不存在 公共子序列 ,返回 0 。

一个字符串的 子序列 是指这样一个新的字符串:它是由原字符串在不改变字符的相对顺序的情况下删除某些字符(也可以不删除任何字符)后组成的新字符串。

  • 例如,"ace" 是 "abcde" 的子序列,但 "aec" 不是 "abcde" 的子序列。

两个字符串的 公共子序列 是这两个字符串所共同拥有的子序列。

示例 1:

输入:text1 = "abcde", text2 = "ace" 
输出:3  
解释:最长公共子序列是 "ace" ,它的长度为 3 。

示例 2:

输入:text1 = "abc", text2 = "abc"
输出:3
解释:最长公共子序列是 "abc" ,它的长度为 3 。

示例 3:

输入:text1 = "abc", text2 = "def"
输出:0
解释:两个字符串没有公共子序列,返回 0 。

提示:

  • 1 <= text1.length, text2.length <= 1000
  • text1 和 text2 仅由小写英文字符组成。
class Solution {
public:int longestCommonSubsequence(string text1, string text2) {}
};

解析代码

状态表示:

        对于两个数组的动态规划,定义状态表是的经验就是:选取第一个数组 [0, i] 区间以及第二个数组 [0, j] 区间作为研究对象。结合题目要求,定义状态表示。

在这道题中,根据题目定义状态表示为:

dp[i][j] 表示: s1 的 [0, i] 区间以及 s2 的 [0, j] 区间内的所有的子序列中,最长公共子序列的长度


状态转移方程:

        分析状态转移方程的经验就是根据最后一个位置的状况,分情况讨论。 对于 dp[i][j] ,可以根据 s1[i] 与 s2[j] 的字符分情况讨论:

  • 两个字符相同, s1[i] = s2[j] :那么最长公共子序列就在 s1 的 [0, i - 1] 以 及 s2 的 [0, j - 1] 区间上找到⼀个最长的,然后再加上 s1[i] 即可。因此 dp[i][j] = dp[i - 1][j - 1] + 1 ;
  • 两个字符不相同, s1[i] != s2[j] :那么最长公共子序列一定不会同时以 s1[i] 和 s2[j] 结尾。那么我们找最长公共子序列时,有下面三种策略:
  1. 去 s1 的 [0, i - 1] 以及 s2 的 [0, j] 区间内找:此时最大长度为 dp[i- 1][j] 。
  2. 去 s1 的 [0, i] 以及 s2 的 [0, j - 1] 区间内找:此时最大长度为 dp[i ][j - 1] 。
  3. 去 s1 的 [0, i - 1] 以及 s2 的 [0, j - 1] 区间内找:此时最大长度为dp[i - 1][j - 1] 。

        我们要三者的最大值即可。但是我们细细观察会发现,第三种包含在第⼀种和第二种情况里面,但是我们求的是最大值,并不影响最终结果。因此只需求前两种情况下的最大值即可。

综上,状态转移方程为:

  • if(s1[i] == s2[j]) dp[i][j] = dp[i - 1][j - 1] + 1 ;
  • if(s1[i] != s2[j]) dp[i][j] = max(dp[i - 1][j], dp[i][j - 1]) ;

初始化、填表顺序、返回值:

        初始化:空串是有研究意义的,因此我们将原始 dp 表的规模多加上一行和一列,表示空串。 引入空串后,大大的方便我们的初始化。 但也要注意下标的映射关系,以及里面的值要保证后续填表是正确的。 当 s1 为空时,没有长度,同理 s2 也是。因此第一行和第一列里面的值初始化为 0 即可保证后续填表是正确的,还可以通过在s1和s2最前面加上一个字符来对应下标的映射

填表顺序:从上往下填写每一行,每一行从左往右,最后返回dp[m][n]。

class Solution {
public:int longestCommonSubsequence(string text1, string text2) {// dp[i][j] 表示: s1 的 [0, i] 区间以及 s2 的 [0, j] 区间// 内的所有的子序列中,最长公共子序列的长度int m = text1.size(), n = text2.size();vector<vector<int>> dp(m + 1, vector<int>(n + 1, 0));// text1 = " " + text1, text2 = " " + text2; // 注释掉,在原数组找i,j就要-1for(int i = 1; i <= m; ++i){for(int j = 1; j <= n; ++j){if(text1[i - 1] == text2[j - 1])dp[i][j] = dp[i - 1][j - 1] + 1;elsedp[i][j] = max(dp[i][j - 1], dp[i - 1][j]);}}return dp[m][n];}
};

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • SpringBoot启动禁用员工账号(动态sql通用修改)
  • “大学论文数据分析全攻略:从理论到实践的实用指南“
  • Redis中的Sentinel(五)
  • FPGA的就业前景
  • 基于Java+SpringBoot+Mybaties+layui+Vue+elememt 实习管理系统 的设计与实现
  • 1.0-spring入门
  • Transformer Based Multi-view Network for Mammographic Image Classification
  • 加密软件VMProtect教程:使用脚本-功能
  • 【御控物联】JavaScript JSON结构转换(14):对象To数组——规则属性重组
  • 设计模式:生活中的观察者模式
  • 【蓝桥杯练习】tarjan算法求解LCA
  • Chapter 1 Basic Concepts of Communication and Communication Systems
  • [Qt]解析moc文件
  • xshell7连接ubuntu18.04
  • CODEFORCES --- 630A. Again Twenty Five!
  • [笔记] php常见简单功能及函数
  • 【许晓笛】 EOS 智能合约案例解析(3)
  • Akka系列(七):Actor持久化之Akka persistence
  • Android单元测试 - 几个重要问题
  • canvas实际项目操作,包含:线条,圆形,扇形,图片绘制,图片圆角遮罩,矩形,弧形文字...
  • Joomla 2.x, 3.x useful code cheatsheet
  • Map集合、散列表、红黑树介绍
  • SpingCloudBus整合RabbitMQ
  • thinkphp5.1 easywechat4 微信第三方开放平台
  • ⭐ Unity 开发bug —— 打包后shader失效或者bug (我这里用Shader做两张图片的合并发现了问题)
  • Wamp集成环境 添加PHP的新版本
  • 案例分享〡三拾众筹持续交付开发流程支撑创新业务
  • 不用申请服务号就可以开发微信支付/支付宝/QQ钱包支付!附:直接可用的代码+demo...
  • 产品三维模型在线预览
  • 大主子表关联的性能优化方法
  • 干货 | 以太坊Mist负责人教你建立无服务器应用
  • 关键词挖掘技术哪家强(一)基于node.js技术开发一个关键字查询工具
  • 老板让我十分钟上手nx-admin
  • 融云开发漫谈:你是否了解Go语言并发编程的第一要义?
  • 使用common-codec进行md5加密
  • 使用前端开发工具包WijmoJS - 创建自定义DropDownTree控件(包含源代码)
  • 一份游戏开发学习路线
  • 【运维趟坑回忆录 开篇】初入初创, 一脸懵
  • 机器人开始自主学习,是人类福祉,还是定时炸弹? ...
  • ​如何防止网络攻击?
  • # Apache SeaTunnel 究竟是什么?
  • ###51单片机学习(2)-----如何通过C语言运用延时函数设计LED流水灯
  • #LLM入门|Prompt#1.8_聊天机器人_Chatbot
  • (17)Hive ——MR任务的map与reduce个数由什么决定?
  • (9)STL算法之逆转旋转
  • (NO.00004)iOS实现打砖块游戏(九):游戏中小球与反弹棒的碰撞
  • (Python) SOAP Web Service (HTTP POST)
  • (STM32笔记)九、RCC时钟树与时钟 第一部分
  • (附源码)springboot 基于HTML5的个人网页的网站设计与实现 毕业设计 031623
  • (实战)静默dbca安装创建数据库 --参数说明+举例
  • (一)十分简易快速 自己训练样本 opencv级联haar分类器 车牌识别
  • (转) RFS+AutoItLibrary测试web对话框
  • (轉)JSON.stringify 语法实例讲解
  • ..回顾17,展望18
  • .bat批处理(二):%0 %1——给批处理脚本传递参数