最长公共子序列(模板 LCSL)
博客:
https://www.cnblogs.com/sasuke-/p/5396843.html
模板
#include<iostream>
#include<cstdio>
#include<cstring>
#define MAXN 1010
using namespace std;
int c[MAXN][MAXN];//保存各个公共子序列的长度
int b[MAXN][MAXN];//记录来源
char s1[MAXN], s2[MAXN];
int len1, len2;
void LCSL()
{
for (int i = 1; i <= len1; ++i)//控制s1序列
{
for (int j = 1; j <= len2; ++j)//控制s2
{
if (s1[i - 1] == s2[j - 1])
{//如果字符相同最长公共子序列+1
c[i][j] = c[i - 1][j - 1] + 1;
b[i][j] = 1; //表示来源自斜对角
}
else
{
if (c[i][j - 1] >= c[i - 1][j])
{
c[i][j] = c[i][j - 1];//继承最相邻原有的最大长度
b[i][j] = 2;//记录来源自左边
}
else
{
c[i][j] = c[i - 1][j];
b[i][j] = 3;
}
}
}
}
}
void print(int i, int j)
{
if (i == 0 || j == 0)return;
if (b[i][j] == 1)
{
print(i - 1, j - 1);
cout << s1[i - 1];
}
else if (b[i][j]==2)
{
print(i, j - 1);
}
else
{
print(i - 1, j);
}
}
int main()
{
cout << "输入s1:" << endl;
cin >> s1;
cout << "输入s2:" << endl;
cin >> s2;
len1 = strlen(s1);
len2 = strlen(s2);
LCSL();
cout << "s1与s2的最长公共子序列为" << c[len1][len2] << endl;
print(len1, len2);
printf("\n");
}
作者:ALINGMAOMAO
出处:https://www.cnblogs.com/ALINGMAOMAO/p/17117693.html
版权:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
· SQL Server 2025 AI相关能力初探