最长公共子序列的代码实现
关于最长公共子序列(LCS)的相关知识,http://blog.csdn.net/liufeng_king/article/details/8500084 这篇文章讲的比较好,在此暂时不再详说。
以下是我代码实现两种方式:递归+递推:
1 #include <bits/stdc++.h> 2 using namespace std; 3 int A[100]; 4 int B[100]; 5 6 //int B[]={2,3,5,6,9,8,4}; 7 int d[100][100]={0}; 8 int dp(int i, int j,vector<int> &vs){ 9 int &ans = d[i][j]; 10 if(ans > 0)return ans; 11 if(i>0&&j>0){ 12 if(A[i] == B[j]){ 13 ans = dp(i-1,j-1)+1; 14 } 15 else ans = max(dp(i-1,j),dp(i,j-1)); 16 } 17 else{ 18 ans = 0; 19 } 20 return ans; 21 } 22 int LCS(int n1, int n2){ 23 for(int i = 0; i <= n1; i++)d[i][0] = 0; 24 for(int i = 0; i <= n2; i++)d[0][i] = 0; 25 for(int i = 1; i<= n1; i++){ 26 for(int j = 1; j<= n2; j++){ 27 if(A[i]==B[j]){ 28 d[i][j] = d[i-1][j-1]+1; 29 } 30 else d[i][j] = max(d[i-1][j], d[i][j-1]); 31 } 32 } 33 return d[n1][n2]; 34 } 35 int main(){ 36 int n1,n2 ; 37 cin >> n1; 38 for(int i = 1;i <= n1; i++) cin >> A[i]; 39 cin >> n2; 40 for(int i = 1;i <= n2; i++) cin >> B[i]; 41 memset(d,-1,sizeof(d)); 42 d[0][0] = 0; 43 vector<int> vs; 44 cout << dp(n1,n2,vs) << endl; 45 cout << LCS(n1 ,n2) << endl; 46 //cout << dp(5,6) << endl; 47 48 return 0; 49 }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架