leetcode1143. 最长公共子序列(动态规划)

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

一个字符串的 子序列 是指这样一个新的字符串:它是由原字符串在不改变字符的相对顺序的情况下删除某些字符(也可以不删除任何字符)后组成的新字符串。
例如,“ace” 是 “abcde” 的子序列,但 “aec” 不是 “abcde” 的子序列。两个字符串的「公共子序列」是这两个字符串所共同拥有的子序列。

若这两个字符串没有公共子序列,则返回 0。
解题思路
数组含义:dp[i][j]text1前i个和text2前j个字符的最长公共子序列的长度。
状态转移:如果当前位置(i,j)的字符相等,则在(i-1,j-1)的结果基础上加1,否则就等于(i-1,j)或者(i,j-1)的结果的较大值。

二维动态规划代码

    public int longestCommonSubsequence(String text1, String text2) {int n=text1.length(),m=text2.length();int[][] dp=new int[n+1][m+1];for(int i=1;i<=n;i++)for(int j=1;j<=m;j++)if(text1.charAt(i-1)==text2.charAt(j-1))dp[i][j]= dp[i-1][j-1]+1;else dp[i][j]= Math.max(dp[i-1][j],dp[i][j-1]);return dp[n][m];}

一维动态规划代码

class Solution {public int longestCommonSubsequence(String text1, String text2) {int n=text1.length(),m=text2.length();int[] dp=new int[m+1];for(int i=1;i<=n;i++){int last=0;for(int j=1;j<=m;j++){int temp=dp[j];if(text1.charAt(i-1)==text2.charAt(j-1))dp[j]=last+1;else dp[j]= Math.max(dp[j-1],dp[j]);last=temp;}}return dp[m];}
}

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

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

相关文章

php开发支付宝支付密码忘记了怎么办_密码箱忘记密码怎么办?密码箱解锁方法大全...

密码箱忘记密码经常发生&#xff0c;有时候急着赶车赶飞机必须用的证件在密码行李箱&#xff0c;怎么办&#xff1f;破坏&#xff1f;当你忘记密码的时候千万不要着急&#xff0c;不要试着用暴力破坏密码锁。操作方法一此类型的密码箱的开锁方法。把箱子放在光线好的地方放平&a…

Python网络编程之TCP服务器客户端(二)

传输控制协议(官方术语为TCP/IP协议)是互联网的重要组成部分。TCP的第一个版本是在1974年定义的&#xff0c;它建立在网际层协议(IP)提供的数据包传输技术之上。TCP使得应用程序可以使用连续的数据流进行相互通信&#xff0c;除非出现网络原因导致连接中断等意外情况&#xff0…

请写出至少5个html块元素标签_34道常见的HTML+CSS面试题(附答案)

公众号【传智播客博学谷】回复关键词&#xff1a;前端 PS Java(100G) Python(80G) 大数据 区块链 测试 PPT JS(40g300教程) HTML 简历 领取相关学习资料&#xff01;一、HTML1、标签上title属性与alt属性的区别是什么&#xff1f;alt属性是为了给那些不能看到你文档中图像的浏览…

leetcode剑指 Offer 42. 连续子数组的最大和(动态规划)

输入一个整型数组&#xff0c;数组里有正数也有负数。数组中的一个或连续多个整数组成一个子数组。求所有子数组的和的最大值。 要求时间复杂度为O(n)。 示例1: 输入: nums [-2,1,-3,4,-1,2,1,-5,4] 输出: 6 解释: 连续子数组 [4,-1,2,1] 的和最大&#xff0c;为 6。 常数…

nginx mozilla_我发现Mozilla的私人浏览模式存在重大缺陷。

nginx mozillaby Konark Modi通过Konark Modi 我发现Mozilla的私人浏览模式存在重大缺陷。 (I found a major flaw in Mozilla’s private browsing mode.) If left unfixed this flaw could have wreaked havoc but Mozilla’s prompt fixes saved the day.如果不加以解决&am…

4月8日随笔

周一满课&#xff0c;晚上唱红歌&#xff0c;写概率论。。 转载于:https://www.cnblogs.com/wxy2000/p/10686058.html

linux开机出现一下错误Give root password for maintenance (or type Control-D to continue):

linux开机出现一下错误Give root password for maintenance (or type Control-D to continue):第一种错误的情况&#xff1a;由于错误的编辑/etc/fstab文件 而引起的不能正常进入系统。假如你将某一个分区或者磁盘最后一个参数设置为1或2时&#xff0c;系统默认会在开机过程中检…

[阅读笔记]Zhang Y. 3D Information Extraction Based on GPU.2010.

1.立体视觉基础 深度定义为物体间的距离 视差定义为同一点在左图(reference image) 和右图( target image) 中的x坐标差。 根据左图中每个点的视差得到的灰度图称为视差图。 那么根据三角几何关系可以由视差(xR - xT ) 计算出深度.bcamera基线距离&#xff0c;f焦距。 离相机越…

r语言 小树转化百分数_“小树”机器人1.0新品发布会

产品初衷伴随着AI的落地&#xff0c;从最开始的刷脸支付&#xff0c;再到自动驾驶&#xff0c;还是现在互联网的5G时代&#xff0c;AI无疑都是产业变革的核心动力。那么作为一家科技创新的企业&#xff0c;小树机器人从建立之初就在不断的创新&#xff0c;我们致力于从智能出发…

mac安装python虚拟环境_详解Mac配置虚拟环境Virtualenv,安装Python科学计算包

最近正在自学Python做科学计算&#xff0c;当然在很多书籍和公开课里最先做的就是安装Numpy, Scipy, Matplotlib等包&#xff0c;不过每次安装单独的包时&#xff0c;都会有各种问题导致安装失败或者调用失败。比如&#xff0c;遇到 Exception 和 Error&#xff1a;明明已经提示…

破解系统设计访谈:Twitter软件工程师的提示

by Zhia Hwa Chong志华化 破解系统设计访谈&#xff1a;Twitter软件工程师的提示 (Crack the System Design interview: tips from a Twitter software engineer) I recently wrote about how I landed offers from multiple top-tier tech companies. During my interview pr…

leetcode474. 一和零(动态规划)

在计算机界中&#xff0c;我们总是追求用有限的资源获取最大的收益。 现在&#xff0c;假设你分别支配着 m 个 0 和 n 个 1。另外&#xff0c;还有一个仅包含 0 和 1 字符串的数组。 你的任务是使用给定的 m 个 0 和 n 个 1 &#xff0c;找到能拼出存在于数组中的字符串的最大…

jQuery对象与DOM对象的相互转换

一、检测方式上的区别 检测DOM对象&#xff1a; if (Object.nodeType) 检测jQery对象&#xff1a; if (Object.jquery) 二、转换方式 jQuery对象转DOM对象&#xff1a; var DOMObject jQueryObject.get([index]); // 或者 var DOMObject jQueryObject[index]; DOM对象转jQuer…

ProcessExplore 最新版

http://files.cnblogs.com/files/zhangdongsheng/ProcessExplorer.zip转载于:https://www.cnblogs.com/zhangdongsheng/p/6195743.html

javascript对象包含哪些要素_让人迷糊的JavaScript对象(Object一)

对于很多初学的小伙伴听到JavaScript内置对象、BOM、DOM、WEB API等关键词基本上都是迷糊&#xff0c;不是很明白他们之间的关系&#xff0c;以及他们是如果建立联系的。虽然我们现在小伙伴在学VUE&#xff0c;React等框架能简化我们的操作&#xff0c;但是遇到一些基础的问题还…

被吐嘈的NodeJS的异常处理

被吐嘈的NodeJS的异常处理 许多人都有这样一种映像&#xff0c;NodeJS比较快&#xff1b; 但是因为其是单线程&#xff0c;所以它不稳定&#xff0c;有点不安全&#xff0c;不适合处理复杂业务&#xff1b; 它比较适合对并发要求比较高&#xff0c;而且简单的业务场景。 在Expr…

javascript关键字_让我们揭开JavaScript的“ new”关键字的神秘面纱

javascript关键字by Cynthia Lee辛西娅李(Cynthia Lee) 让我们揭开JavaScript的“ new”关键字的神秘面纱 (Let’s demystify JavaScript’s ‘new’ keyword) Over the weekend, I completed Will Sentance’s JavaScript: The Hard Parts. It might not sound like the most…

查看 rabbitmq 启动websocket 提示404_RabbitMQ在windows下安装(笔记)

先保证Java开发环境一切正常&#xff0c;【jdk,maven】,然后下载两个文件&#xff0c;1&#xff0c;下载OTPhttps://www.rabbitmq.com/download.html 下载地址下载RabbitMQ Downloading and Installing RabbitMQ:地址安装没有别的操作&#xff0c;一直下一步就好&#xff1b;2&…

[Leetcode] Longest Valid Parentheses

找出字串裡最長的合法括號組 簡單說&#xff0c;一樣stack搜尋合法parenth&#xff0c;把不合法的 ( & ) index 紀錄下來&#xff0c;最後算index間的差值取最大就是最長的 public class Solution{/// <summary>/// 把不合法的( )的index記下來&#xff0c;取最長的差…

leetcode35. 搜索插入位置(二分搜索)

给定一个排序数组和一个目标值&#xff0c;在数组中找到目标值&#xff0c;并返回其索引。如果目标值不存在于数组中&#xff0c;返回它将会被按顺序插入的位置。 你可以假设数组中无重复元素。 示例 1: 输入: [1,3,5,6], 5 输出: 2 代码 class Solution {public int sear…