LCS(递归/记忆化/dp)

news/2025/1/18 14:02:32/文章来源:https://www.cnblogs.com/benscode/p/18678425

题目链接: https://leetcode.cn/problems/longest-common-subsequence/

TLE

暴力递归+记忆化版本(基于字符串长度无优化版本)//注意text1[i1-1]==text2[i2-1]

class Solution {
public:int dp[1000][1000];int longestCommonSubsequence(string text1, string text2) {int n=text1.size();int m=text2.size();memset(dp,-1,sizeof(dp));return f(dp,text1,text2,n,m);}int f(int dp[][1000],string t1,string t2,int i1,int i2){//basecaseif(dp[i1][i2]!=-1)return dp[i1][i2];if(i1==0||i2==0){dp[i1][i2]=0;return 0;}try(四种不同可能性)int p1=f(dp,t1,t2,i1-1,i2);int p2=f(dp,t1,t2,i1-1,i2-1);int p3=f(dp,t1,t2,i1,i2-1);int p4= t1[i1-1]==t2[i2-1]? p2+1: p2;int big=max(max(p1,p2),max(p3,p4));dp[i1][i2]=big;return dp[i1][i2];}
};

暴力递归+记忆化(基于字符串长度的优化版本)(感觉上是能通过的,但其实没有)

class Solution {
public:int dp[1005][1005];int longestCommonSubsequence(string text1, string text2) {int n=text1.size();int m=text2.size();memset(dp,-1,sizeof(dp));return f(dp,text1,text2,n,m);}int f(int dp[][1005],string t1,string t2,int i1,int i2){if(dp[i1][i2]!=-1)return dp[i1][i2];if(i1==0||i2==0){dp[i1][i2]=0;return 0;}if(t1[i1-1]==t2[i2-1]){dp[i1][i2]=f(dp,t1,t2,i1-1,i2-1)+1;return dp[i1][i2];}else{dp[i1][i2]=max(f(dp,t1,t2,i1-1,i2),f(dp,t1,t2,i1,i2-1));return dp[i1][i2];}}
};

二维DP

普通版本

class Solution {
public:int dp[1005][1005];int longestCommonSubsequence(string text1, string text2) {int n=text1.size();int m=text2.size();memset(dp,0,sizeof(dp));for(int i=1; i<=n; i++){for(int j=1; j<=m;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[n][m];}};

状压版本

class Solution {
public:int longestCommonSubsequence(string text1, string text2) {string s1;string s2;if(text1.size()>text2.size()){s1=text1;s2=text2;}else{s1=text2;s2=text1;}int n=s1.size();int m=s2.size();vector<int>dp(m+1,0);for(int i=1;i<=n;i++){int left=0;for(int j=1;j<=m;j++){if(s1[i-1]==s2[j-1]){int cur=dp[j];dp[j]=left+1;left=cur;}else{left=dp[j];dp[j]=max(dp[j],dp[j-1]);}}}return dp[m];}};

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

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

相关文章

day0java准备

Java-001 Markdown 暂时跳过,vscode里未能实现编译 java 1.已配置环境 2.继续学黑马程序员:已到50/200 3.内存4.学到方法(C里函数)

NB!一款基于java开发的漏洞检测工具,集合了泛微、用友、大华、海康、致远、红帆、万户、帆软等漏洞

1、工具介绍 基于 https://github.com/yhy0/ExpDemo-JavaFX 上添加poc 2、工具下载链接: 工具下载:工具下载 3、新增检测漏洞用友NC-Cloud系统接口getStaffInfo存在SQL注入漏洞 用友U8-Cloud ReleaseRepMngAction存在SQL注入漏洞复现(CNVD-2024-33023) 用友U8-CRM系统getDeptN…

网络购物数据分析

#获取数据 import pandas as pd infor=pd.read_csv(buy_input_1.csv) infor.head(20) #选取预观察数据#方法1 # x1=infor["Annual Income"] # print(x1) # x2=infor["Spending Score"] # print(x2)# """ #方法2 # x1=infor.iloc[:,3] # …

了解ESP32睡眠模式及其功耗

转载自:https://lastminuteengineers.com/esp32-sleep-modes-power-consumption/ Insight Into ESP32 Sleep Modes & Their Power ConsumptionThe ESP32 is undeniably a worthy competitor to many WiFi/MCU SoCs, outperforming them in both performance and price. Ho…

某公交管理系统简易逻辑漏洞+SQL注入挖掘

某公交管理系统挖掘 SQL注入漏洞 前台通过给的账号密码,进去 按顺序依次点击1、2、3走一遍功能点,然后开启抓包点击4当点击上图的4步骤按钮时,会抓到图下数据包,将其转发到burp的重放模块构造以下注入poc,可见注入延时了五秒,用户输入的语句成功拼接到原有的SQL语句上执行…

记一次常规的网络安全渗透测试

前言 上个月根据领导安排,需要到本市一家电视台进行网络安全评估测试。通过对内外网进行渗透测试,网络和安全设备的使用和部署情况,以及网络安全规章流程出具安全评估报告。本文就是记录了这次安全评估测试中渗透测试部分的内容,而且客户这边刚刚做过了一次等保测评,算一下…

工具 | Hfish

0x00 简介 HFish是一款社区型免费蜜罐。 下载地址 HFish下载: HFish下载 0x01 功能说明支持多种蜜罐服务支持自定义Web蜜罐支持流量牵引支持端口扫描感知能力支持多种告警方式注:仅供安全研究与学习之用,若将工具做其他用途,由使用者承担全部法律及连带责任,作者及发布者不…

ida(持续更新)

如题前缀 说明sub_ 指令和子函数起点locret_ 返回指令loc_ 指令off_ 数据,包含偏移量seg_ 数据,包含段地址值asc_ 数据,ASCII字符串byte_ 数据,字节(或字节数组)word_ 数据,16位数据(或字数组)dword_ 数据,32位数据(或双字数组)qword_ 数据,64位数据(或4字数组)…

工具 | Hashcat

0x00 简介 Hashcat是一款强大的密码破解工具。 下载地址 Hashcat下载: Hashcat下载 0x01 功能说明直接破解组合攻击掩码暴力破解混合攻击联合攻击注:仅供安全研究与学习之用,若将工具做其他用途,由使用者承担全部法律及连带责任,作者及发布者不承担任何法律及连带责任。

深入理解主键和外键:数据库设计的基石

title: 深入理解主键和外键:数据库设计的基石 date: 2025/1/18 updated: 2025/1/18 author: cmdragon excerpt: 在现代信息系统中,数据的管理和存储是至关重要的。关系数据库作为一种广泛使用的数据存储方式,其设计的合理性直接影响到数据的完整性和系统的性能。在关系数据…

一次性讲清如何合理搭配一台组装电脑

今天这篇文章我就给大家一次性讲清,我们如何合理搭配组装一台电脑,新手小白建议收藏观看,希望对大家有所帮助。 1 .首先要知道组装一台电脑, 以下八大硬件缺一不可: 2. 认识【CPU】: CPU品牌: 目前市场主流消费级CPU只有英特尔与AMD。 英特尔CPU: intel的CPU分为i3、i5、i…

ADCP414、ADCP416四通道125MSPS速率ADC替代AD9653、AD9253,可提供ZZKK证明

ADCP416-125/105/80是一款4通道、16位、125/105/80MSPS模数转换器(ADC),内置片内采样保持电路,专门针对低成本、低功耗、小尺寸和易用性而设计。该产品的转换速率最高可达125MSPS,具有杰出的动态性能与低功耗特性,适合比较重视小封装尺寸的应用。ADCP416-125特性和优势 --电…