hud1151 動態規劃 最大的公共子序列
就是求最大公共子序列,很經典的一題,這題就當複習演算法啦
遞推公式:
c[i][j]=c[i-1][j-1]+1 當a[i-1]==b[j-1]時
c[i][j]=c[i-1][j]>c[i][j-1]?c[i-1][j]:c[i][j-1] 當a[i-1]!=a[j-1]時
#include<stdio.h>
#include<cstring>
int c[500][500];
char a[500],b[500];
int LCS(int m,int n)
{
int i,j;
for(int i=1;i<=m;i++)
{
for(int j=1;j<=n;j++){
if(a[i-1]==b[j-1])
{
c[i][j]=c[i-1][j-1]+1;
}
else{
c[i][j]=c[i-1][j]>c[i][j-1]?c[i-1][j]:c[i][j-1];
}
}
}
return c[m][n];
}
int main()
{
int i,j,m,n;
while(scanf("%s %s",a,b)!=EOF)
{
memset(c,0,sizeof(c));
i=strlen(a);
j=strlen(b);
printf("%d\n",LCS(i,j));
}
return 0;
}
相關文章
- 動態規劃-最長公共子序列動態規劃
- 動態規劃——最長公共子序列動態規劃
- 動態規劃(最長公共子序列LCS)動態規劃
- 動態規劃之最長公共子序列求解動態規劃
- 力扣1143. 最長公共子序列 動態規劃之最長公共子序列力扣動態規劃
- 最長公共子序列問題—動態規劃sdut動態規劃
- 動態規劃經典問題----最長公共子序列動態規劃
- 詳解動態規劃最長公共子序列--JavaScript實現動態規劃JavaScript
- 動態規劃:最長上升子序列動態規劃
- 最長上升子序列動態規劃動態規劃
- 淺談最長公共子序列引發的經典動態規劃問題動態規劃
- 以最長公共子序列問題理解動態規劃演算法(DP)動態規劃演算法
- 動態規劃-最長上升子序列模型動態規劃模型
- 雙序列動態規劃動態規劃
- LeetCode 1626. 無矛盾的最佳球隊---【動態規劃】最長上升子序列變換版-->最大上升子序列和LeetCode動態規劃
- [LeetCode解題] -- 動態規劃二 [ 子串、子序列問題 ]LeetCode動態規劃
- 動態規劃求解最長上升子序列問題動態規劃
- 【LeetCode動態規劃#14】子序列系列題(最長遞增子序列、最長連續遞增序列、最長重複子陣列、最長公共子序列)LeetCode動態規劃陣列
- python 動態規劃(揹包問題和最長公共子串)Python動態規劃
- 禮物的最大價值(一維動態規劃&二維動態規劃)動態規劃
- 動態規劃之子序列問題動態規劃
- 動態規劃最大欄位和動態規劃
- 動態規劃求最長降序序列動態規劃
- 北京大學郭煒-最長上升子序列 動態規劃講解動態規劃
- Leetcode 題解系列 -- 股票的最大利潤(動態規劃)LeetCode動態規劃
- LeetCode 300. 最長上升子序列(Python、動態規劃、貪心演算法)LeetCodePython動態規劃演算法
- 最長公共子序列
- [LeetCode 中等 動態規劃 ]221. 最大正方形LeetCode動態規劃
- 磁帶最大利用率問題——動態規劃動態規劃
- 動態規劃動態規劃
- [動態規劃] 六、最長迴文子串動態規劃
- 程式碼隨想錄演算法訓練營第五十三天| ● 1143.最長公共子序列 ● 1035.不相交的線 ● 53. 最大子序和 動態規劃演算法動態規劃
- 最長公共子序列(JAVA)Java
- 動態規劃之數的劃分動態規劃
- [leetcode] 動態規劃(Ⅰ)LeetCode動態規劃
- 動態規劃法動態規劃
- 模板 - 動態規劃動態規劃
- 動態規劃初步動態規劃
- 動態規劃分析動態規劃