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

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 仅由小写英文字符组成。

总结:如果需要确定 保证某种次序,就需要确定以....结尾的序列。

//如果 许需要保证 答案序列 需要维持 顺序,只要符合条件就可以加进去的。定义为 在0-i区间的字符串是否符合。

class Solution {
public:int longestCommonSubsequence(string text1, string text2) {//求递增序列的时候,因为要求序列有序,所以必须确定序列最后一个元素的值,才能比较新加入序列的元素是不是递增的。求相等序列的时候,如果求连续相等子序列,则还是要确定序列最后一个元素的值;但是本题求的是不必连续的相等子序列,就不需要知道序列最后一个元素的值,只要知道范围内相等的序列长度就行,新来的相等元素可以直接加在序列后面。//dp[i][j]:长度为0- i-1 的text1的字符串 和 长度为0- j-1的text2字符串的最长公共子序列长度为 dp[i][j]   还是从1开始,方便初始化//递推关系:如果 t1[i-1] == t2[i-1] 那么 dp[i][j] = dp[i-1][j-1]+1;//如果 !=  那么 dp[i][j] = max(dp[i-1][j], dp[i][j-1])。继承t1的上一个 和t2的上一个 的最大值  t1 = abcde   //     t2 = ace   c和e不相等,那么可以从 t1中的 abc 和 t2的ac找。也可以从t2的ace 和 t1中的 ac找//初始化:考虑 dp[i][0]  dp[0][j]  0-1已经越界了,可以理解为t1字符串 和空字符串的交集为0。所以第一行和第一列都为0。因此其他所有行都可以为0,因为会被覆盖vector<vector<int>>dp(text1.size()+1,vector<int>(text2.size()+1,0));for(int i = 1;i <= text1.size();i++){for(int j = 1;j <= text2.size();j++){if(text1[i-1] == text2[j-1]){dp[i][j] = dp[i-1][j-1] + 1;}else dp[i][j] = max(dp[i-1][j], dp[i][j-1]);}}return dp[text1.size()][text2.size()];}
};

相关文章:

1143. 最长公共子序列

给定两个字符串 text1 和 text2&#xff0c;返回这两个字符串的最长 公共子序列 的长度。如果不存在 公共子序列 &#xff0c;返回 0 。 一个字符串的 子序列 是指这样一个新的字符串&#xff1a;它是由原字符串在不改变字符的相对顺序的情况下删除某些字符&#xff08;也可以…...

EASYEXCEL(一)

1.读取excel 读监听器 Slf4j public class StudentReadListener extends AnalysisEventListener<Student> {// 每读一样&#xff0c;会调用该invoke方法一次Overridepublic void invoke(Student data, AnalysisContext context) {System.out.println("data "…...

竞赛YOLOv7 目标检测网络解读

文章目录 0 前言1 yolov7的整体结构2 关键点 - backbone关键点 - head3 训练4 使用效果5 最后 0 前言 世界变化太快&#xff0c;YOLOv6还没用熟YOLOv7就来了&#xff0c;如果有同学的毕设项目想用上最新的技术&#xff0c;不妨看看学长的这篇文章&#xff0c;学长带大家简单的…...

第一类曲线积分@对弧长的曲线积分

文章目录 abstract对弧长的曲线积分曲线形构件的质量第一类曲线积分曲线积分存在性利用曲线积分的定义描述曲线形构件质量问题推广曲线积分可加性闭曲线积分 曲线积分性质曲线积分的计算方法证明(部分推导) 小结曲线弧显函数形式方程下的曲线积分公式推广例例例 abstract 在积…...

【TypeScript】常见数据结构与算法(二):链表

文章目录 链表结构&#xff08;LinkedList&#xff09;链表以及数组的缺点数组链表的优势 什么是链表?封装链表相关方法源码链表常见面试题237-删除链表中的节点206 - 反转链表 数组和链表的复杂度对比 链表结构&#xff08;LinkedList&#xff09; 链表以及数组的缺点 链表…...

原型模式 (Prototype Pattern)

定义&#xff1a; 原型模式&#xff08;Prototype Pattern&#xff09;是一种创建型设计模式&#xff0c;它用于创建重复的对象&#xff0c;同时保持性能。这种模式的核心思想是通过复制一个已存在的实例来创建新的实例&#xff0c;而不是新建实例并对其进行初始化。原型模式适…...

项目总结报告(案例模板)

软件项目总结报告模板套用&#xff1a; 项目概要项目工作分析经验与教训改进建议可纳入的项目过程资产 --------进主页获取更多资料-------...

C++ Qt QByteArray用法介绍

作者:令狐掌门 技术交流QQ群:675120140 csdn博客:https://mingshiqiang.blog.csdn.net/ 文章目录 一、QByteArray的基本用法1、初始化和赋值2、访问和修改元素3、 常用方法4、数据转换二、QByteArray与文件操作三、QByteArray与网络编程四、QByteArray数据编码1、Base64 编解…...

蓝桥杯物联网竞赛_STM32L071_3_Oled显示

地位&#xff1a; 对于任何一门编程语言的学习&#xff0c;print函数毫无疑问是一种最好的调试手段&#xff0c;调试者不仅能通过它获取程序变量的运行状态而且通过对其合理使用获取程序的运行流程&#xff0c;更能通过关键变量的输出帮你验证推理的正确与否&#xff0c;朴素的…...

python-opencv轮廓检测(外轮廓检测和全部轮廓检测,计算轮廓面积和周长)

python-opencv轮廓检测&#xff08;外轮廓检测和全部轮廓检测&#xff0c;计算轮廓面积和周长&#xff09; 通过cv2.findContours&#xff0c;我们可以进行轮廓检测&#xff0c;当然也有很多检测模式&#xff0c;我们可以通过选择检测模式&#xff0c;进行外轮廓检测&#xff…...

LeetCode [简单] 1. 两数之和

给定一个整数数组 nums 和一个整数目标值 target&#xff0c;请你在该数组中找出 和为目标值 target 的那 两个 整数&#xff0c;并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是&#xff0c;数组中同一个元素在答案里不能重复出现。 你可以按任意顺序返回…...

C++设计模式之工厂模式(下)——抽象工厂模式

抽象工厂模式 介绍示例示例使用运行结果抽象工厂模式的优缺点优点缺点 总结 介绍 抽象工厂模式是一种创建型设计模式&#xff0c;它提供了一种封装一组相关或相互依赖对象的方式&#xff0c;而无需指定它们具体的类。它允许客户端使用抽象接口来创建一系列相关的对象&#xff…...

2023亚太杯数学建模A题思路分析 - 采果机器人的图像识别技术

1 赛题 问题A 采果机器人的图像识别技术 中国是世界上最大的苹果生产国&#xff0c;年产量约为3500万吨。与此同时&#xff0c;中国也是世 界上最大的苹果出口国&#xff0c;全球每两个苹果中就有一个&#xff0c;全球超过六分之一的苹果出口 自中国。中国提出了一带一路倡议…...

关于Flink的旁路缓存与异步操作

1. 旁路缓存 1. 什么是旁路缓存? 将数据库中的数据,比较经常访问的数据,保存起来,以减少和硬盘数据库的交互 比如: 我们使用mysql时 经常查询一个表 , 而这个表又一般不会变化,就可以放在内存中,查找时直接对内存进行查找,而不需要再和mysql交互 2. 旁路缓存例子使用 dim层…...

MyBatis-Plus的分页插件和乐观锁插件

MyBatis-Plus: 探索分页查询和乐观锁插件 在现代的Web应用开发中&#xff0c;高效的数据处理是不可或缺的一部分。MyBatis-Plus&#xff0c;作为MyBatis的增强版&#xff0c;提供了多种插件来简化和优化数据库操作。在这篇博客中&#xff0c;我们将重点介绍两个非常实用的插件…...

批量将本地N个英文Html文档进行中文翻译-操作篇

Unity3D特效百例案例项目实战源码Android-Unity实战问题汇总游戏脚本-辅助自动化Android控件全解手册再战Android系列Scratch编程案例软考全系列Unity3D学习专栏蓝桥系列ChatGPT和AIGC &#x1f449;关于作者 专注于Android/Unity和各种游戏开发技巧&#xff0c;以及各种资源分…...

解决cad找不到vcruntime140.dll的方法,实测有效的5个的方法

最近&#xff0c;我在使用CAD软件时遇到了一个困扰我已久的问题&#xff1a;由于找不到vcruntime140.dll文件而导致CAD无法正常运行。经过一番努力和尝试&#xff0c;我终于找到了解决这个问题的方法。那么&#xff0c;如何解决vcruntime140.dll丢失的问题呢&#xff1f;本文将…...

2023亚太杯数学建模C题:我国新能源电动汽车的发展趋势,思路模型代码

问题C 我国新能源电动汽车的发展趋势 赛题思路&#xff1a;获取思路见文末名片&#xff0c;第一时间更新 新能源汽车是指以先进技术原理、新技术、新结构的非常规汽车燃料为动力来源( 非常规汽车燃料指汽油、柴油以外的燃料&#xff09;&#xff0c;将先进技术进行汽车动力控制…...

英语学习-爆破音

英文爆破音有&#xff1a;[p],[b],[t],[d],[k],[g]。 同时爆破音的发音会根据前后音的不同&#xff0c;发音不同&#xff0c;具体如下&#xff1a; ⒈ [p],[b],[t],[d],[k],[g] 中的任何两个音素相邻时&#xff0c;前面的发不完全爆破音&#xff0c;后面的就要完全地爆破。如…...

【Vue】图片切换

上一篇&#xff1a; vue的指令 https://blog.csdn.net/m0_67930426/article/details/134599378?spm1001.2014.3001.5502 本篇所需要的指令有&#xff1a; v-on v-bind v-show <!DOCTYPE html> <html lang"en"> <head><meta charset"…...

别再为ModelSim仿真头疼了!手把手教你用Quartus 13.0搭建VHDL七段译码器(附完整库文件配置)

Quartus 13.0与ModelSim仿真全攻略&#xff1a;从零搭建VHDL七段译码器 刚接触FPGA开发的朋友们&#xff0c;是否曾在Quartus和ModelSim的配合使用中遇到过各种"玄学"问题&#xff1f;明明代码编译通过了&#xff0c;仿真时却一片空白&#xff1b;或者波形文件加载了…...

Python GMSSL v3.2.1实战:手把手教你搞定SM2国密算法的签名与验签(附ID处理避坑指南)

Python GMSSL v3.2.1实战&#xff1a;SM2国密算法签名与验签全流程解析 当安全工程师第一次在项目中看到"需要支持SM2签名"的需求时&#xff0c;往往会被各种国标文档和参数转换搞得晕头转向。作为我国自主研发的椭圆曲线公钥密码算法&#xff0c;SM2在政务、金融等领…...

5步快速上手《缺氧》存档编辑器:Duplicity终极指南

5步快速上手《缺氧》存档编辑器&#xff1a;Duplicity终极指南 【免费下载链接】oni-duplicity A web-hosted, locally-running save editor for Oxygen Not Included. 项目地址: https://gitcode.com/gh_mirrors/on/oni-duplicity Duplicity是一款基于Web的《缺氧》&am…...

AI东风下新易盛市值一年涨10倍,146名员工凭股权激励坐拥35亿账面市值

新易盛市值一年涨10倍&#xff0c;员工股权激励大丰收从100亿到500亿&#xff0c;新易盛用了快十年&#xff1b;而从500亿到6000亿&#xff0c;仅用了一年时间。这家诞生于成都的光模块企业&#xff0c;去年4月至今股价翻近10倍&#xff0c;成为成都市值最高的公司。在2024年&a…...

告别手动拖拽!用Lumerical脚本批量搭建FDTD仿真结构(附完整代码)

告别手动拖拽&#xff01;用Lumerical脚本批量搭建FDTD仿真结构&#xff08;附完整代码&#xff09; 在光子学仿真领域&#xff0c;时间就是创新的货币。当你在凌晨三点反复调整第37个纳米柱的旋转角度时&#xff0c;是否想过&#xff1a;那些本应用于突破性思考的精力&#xf…...

别再只会optimizer.step()了!详解PyTorch优化器的param_groups与动态调参技巧

深入PyTorch优化器&#xff1a;掌握param_groups与动态调参的艺术 当你第一次接触PyTorch训练循环时&#xff0c;可能只学会了最基本的optimizer.step()调用。但随着项目复杂度提升&#xff0c;你会发现优化器的能力远不止于此。本文将带你深入探索param_groups这个强大却常被忽…...

iOS开发者必看:深度解析.plist文件,从蒲公英/Fir平台安全提取IPA的底层原理

iOS应用分发技术解析&#xff1a;深入理解.plist文件与安全获取IPA的底层逻辑 在企业签名和TestFlight之外&#xff0c;第三方应用分发平台为开发者提供了另一种灵活的应用测试与分发途径。这些平台通过精心设计的机制保护应用资源&#xff0c;而理解其背后的技术原理不仅能满足…...

S32K148的FlexCAN FD从零到跑通:基于S32KDS 2.2和SDK 3.0.0的保姆级配置流程

S32K148的FlexCAN FD从零到跑通&#xff1a;基于S32KDS 2.2和SDK 3.0.0的保姆级配置流程 对于刚接触NXP S32K系列微控制器的开发者来说&#xff0c;FlexCAN FD模块的配置往往是一个令人头疼的挑战。本文将带你从零开始&#xff0c;一步步完成S32K148开发板上FlexCAN FD模块的完…...

从PID到LADRC:一个电源工程师的实战升级笔记(以STM32控制Buck电路为例)

从PID到LADRC&#xff1a;一个电源工程师的实战升级笔记&#xff08;以STM32控制Buck电路为例&#xff09; 作为一名长期使用PID控制Buck电路的电源工程师&#xff0c;我曾在负载突变和输入电压波动时反复调试参数却收效甚微。直到接触LADRC&#xff08;线性自抗扰控制&#xf…...

GROMACS性能调优实战:如何利用GPU和PME参数将模拟速度提升5倍以上

GROMACS性能调优实战&#xff1a;如何利用GPU和PME参数将模拟速度提升5倍以上 当你的分子动力学模拟开始像蜗牛爬行&#xff0c;每个纳秒需要数天甚至数周才能完成时&#xff0c;科研进度就会陷入停滞。对于研究膜蛋白、核酸复合物等大型体系的研究者来说&#xff0c;这种等待尤…...