94、动态规划-最长公共子序列

  1. 递归的基本思路
    • 比较两个字符串的最后一个字符。如果相同,则这个字符一定属于最长公共子序列,然后在剩余的字符串上递归求解。
    • 如果最后一个字符不相同,则分两种情况递归求解:
      • 去掉 text1 的最后一个字符,保留 text2 的所有字符。
      • 去掉 text2 的最后一个字符,保留 text1 的所有字符。
    • 取两种情况的最大值作为最终结果。
  2. 递归的终止条件
    • 如果任一字符串为空,则公共子序列长度为0。

代码如下:

public class Solution {public int longestCommonSubsequence(String text1, String text2) {return lcs(text1, text2, text1.length(), text2.length());}private int lcs(String text1, String text2, int i, int j) {// 终止条件:任一字符串长度为0if (i == 0 || j == 0) {return 0;}// 递归计算if (text1.charAt(i - 1) == text2.charAt(j - 1)) {// 最后一个字符相同,是LCS的一部分return 1 + lcs(text1, text2, i - 1, j - 1);} else {// 最后一个字符不同,选择不包含text1[i-1]或text2[j-1]的最大LCSreturn Math.max(lcs(text1, text2, i - 1, j), lcs(text1, text2, i, j - 1));}}
}

动态规划是优化递归的方法,使用表格来存储中间结果,避免重复计算。

  1. 定义状态

    • dp[i][j] 表示 text1[0...i-1]text2[0...j-1] 的最长公共子序列的长度。
  2. 状态转移方程

    • 如果 text1[i-1] == text2[j-1],则 dp[i][j] = dp[i-1][j-1] + 1
    • 如果 text1[i-1] != text2[j-1],则 dp[i][j] = max(dp[i-1][j], dp[i][j-1])
  3. 初始化

    • 初始化 dp 数组,当 ij 为0时,dp[i][j] = 0,表示一个字符串为空。
  4. 填表顺序

    • 由于每个 dp[i][j] 依赖于左边、上边和左上角的值,因此应从上到下、从左到右填表。
  5. 返回结果

    • dp[text1.length()][text2.length()] 即为两个字符串的最长公共子序列的长度。

代码如下:

public int longestCommonSubsequence(String text1, String text2) {// 获取输入字符串的长度int m = text1.length(), n = text2.length();// 创建动态规划表,多出的一行一列用于处理边界情况,即某一字符串长度为0的情况int[][] dp = new int[m + 1][n + 1];// 填充动态规划表for (int i = 1; i <= m; i++) {for (int j = 1; j <= n; j++) {// 检查当前位置的字符是否相同if (text1.charAt(i - 1) == text2.charAt(j - 1)) {// 如果当前两个字符相同,那么这两个字符属于LCS的一部分// 因此dp[i][j]等于左上角的值加1dp[i][j] = dp[i - 1][j - 1] + 1;} else {// 如果当前两个字符不相同,则LCS长度取决于不包含当前字符的子问题的最大值// 即从左边或上边继承最大值dp[i][j] = Math.max(dp[i - 1][j], dp[i][j - 1]);}}}// 返回最终结果,即整个字符串的最长公共子序列长度return dp[m][n];}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/681154.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用Maven对Scala独立应用程序进行编译打包

一、 安装Maven 1.解压&#xff0c;移动安装包 sudo tar -zxf ~/apache-maven-3.9.6-bin.tar.gz -C /usr/local/ cd /usr/local/ sudo mv apache-maven-3.9.6/ ./maven-3.9.6 sudo chown -R qiangzi ./maven-3.9.6 二、Scala应用程序代码 1.在终端中执行如下命令创建一个文…

学习笔记:【QC】Android Q - IMS 模块

一、IMS init 流程图 高清的流程图参考&#xff1a;【高清图&#xff0c;保存后可以放大看】 二、IMS turnon 流程图 高清的流程图参考&#xff1a;【高清图&#xff0c;保存后可以放大看】 三、分析说明 1、nv702870 不创建ims apn pdp 2、nv702811 nv702811的时候才创建…

企业网盘竟还能这样用,可道云teamOS:三大冷门使用技巧分享

在日常工作中&#xff0c;大家是否有为海量的文件的管理感到头疼&#xff1f; 每当急需某个重要文件时&#xff0c;总是在各种文件夹中寻寻觅觅半天。这种困扰&#xff0c;我相信许多人都有过。 在这种时候&#xff0c;专业的文件管理软件能帮助我们解决大部分的麻烦。 今天我…

【PX4-AutoPilot教程-TIPS】Matlab使用ROS Toolbox编译MAVROS2消息报错缺少geographic_msgs消息

Matlab使用ROS Toolbox编译MAVROS2消息报错缺少geographic_msgs消息的解决方法 问题描述解决方法 环境&#xff1a; MATLAB : R2022b ROS Toolbox : 1.6 Windows &#xff1a;Windows 10 22H2 ROS &#xff1a;ROS2 Foxy 问题描述 在使用Matlab的ROS Toolbox工具箱编译与…

漫画对话 ai翻译

復讐の教科書ーー81 81-1 いい加減吐け&#xff01;&#xff01;冴木&#xff01;&#xff01; 快说吧&#xff01;&#xff01;冴木&#xff01;&#xff01; お前が一連の事件の犯人なんだろ&#xff01;&#xff1f; 你就是连续事件的犯人吧&#xff01;&#xff1f; だか…

59. 【Android教程】多线程

多线程可以让你同时异步执行多种任务&#xff0c;是各种编程语言里很重要的一个概念。合理的采用多线程可以让你的 App 拥有更好的运行性能&#xff0c;但是如果使用不当可能会让你的程序非常混乱&#xff0c;出现很多令人费解且难以定位的问题。 1. 多线程初探 当用户打开一个…

python+pycharm安装教程

介绍 Python提供了高效的高级数据结构&#xff0c;还能简单有效地面向对象编程。Python语法和动态类型&#xff0c;以及解释型语言的本质&#xff0c;使它成为多数平台上写脚本和快速开发应用的编程语言&#xff0c;Python解释器易于扩展&#xff0c;可以使用C、C或其他可以通过…

企业为什么要自己搭建企业邮箱?

近年来&#xff0c;随着企业信息化建设的加速&#xff0c;企业邮箱在企业的对外沟通和对内管理过程中发挥着重要作用&#xff0c;已经成为企业使用频次高的办公应用之一。然而&#xff0c;随着企业邮箱的广泛应用以及所产生的数据越来越多&#xff0c;也为企业的运营带来了巨大…

【excel】数据非数值导致排序失效

场景 存在待排序列的数值列&#xff0c;但排序失效&#xff0c;提示类型有问题&#xff1a; 解决 选中该列&#xff0c;数据→分列 而后发现提示消失&#xff0c;识别为数字&#xff0c;可正常排序。

地下水位自动监测设备:矿井水文监测系统

TH-DSW2地下水位自动监测设备具有实时性、连续性和自动化等特点&#xff0c;广泛应用于地下水深井水位测量、矿山深井水位测量、地热井水位测量。可以实现对地下水位的24小时不间断监测。它在城市供水和水资源管理、农业灌溉、地质和地下探测等领域具有广泛的应用。 在城市供水…

kali下Nessus漏扫工具的安装-超级详细

Nessus的安装 下载软件地址&#xff1a;https://www.tenable.com/downloads/nessus?loginAttemptedtrue 1、拷贝软件包到kali家目录下 2、使用root用户进行解压 ┌──(kali㉿kali)-[~/桌面] └─$ sudo -i #切换管理员root [sudo] kali 的密码&#xff1a; #移动软件到…

​「Python绘图」绘制太极图

python 绘制太极 一、预期结果 二、核心代码 import turtlepen turtle.Turtle()print("开始绘制太极")radius 100 pen.color("black", "black") pen.begin_fill() pen.circle(radius/2, 180) pen.circle(radius, 180) pen.left(180) pen.circ…