国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

Common Subsequence [dp]

2019-11-11 02:17:00
字體:
來源:轉載
供稿:網友

A subsequence of a given sequence is the given sequence with some elements (possible none) left out. Given a sequence X = < x1, x2, …, xm > another sequence Z = < z1, z2, …, zk > is a subsequence of X if there exists a strictly increasing sequence < i1, i2, …, ik > of indices of X such that for all j = 1,2,…,k, x ij = zj. For example, Z = < a, b, f, c > is a subsequence of X = < a, b, c, f, b, c > with index sequence < 1, 2, 4, 6 >. Given two sequences X and Y the PRoblem is to find the length of the maximum-length common subsequence of X and Y.

Input

The program input is from the std input. Each data set in the input contains two strings representing the given sequences. The sequences are separated by any number of white spaces. The input data are correct.

Output

For each set of data the program prints on the standard output the length of the maximum-length common subsequence from the beginning of a separate line. Sample Input abcfbc abfcab programming contest abcd mnp

Sample Output

4 2 0

題解

dp入門題

#include<stdio.h>#include<string.h>#include<algorithm>#define MAX_N 500using namespace std;int dp[2][MAX_N];char a[MAX_N],b[MAX_N];int main(){ while(~scanf("%s%s",a+1,b+1)){ int A=strlen(a+1); int B=strlen(b+1); memset(dp,0,sizeof(dp)); for(int j=1;j<=A;j++) for(int k=1;k<=B;k++){ if(a[j]==b[k]) dp[j&1][k]=dp[(j-1)&1][k-1]+1; else dp[j&1][k]=max(dp[(j-1)&1][k],dp[j&1][k-1]); } printf("%d/n",dp[A&1][B]); } return 0;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 景宁| 云梦县| 察哈| 临沭县| 彭山县| 克拉玛依市| 定襄县| 六枝特区| 桐城市| 驻马店市| 恩施市| 绿春县| 申扎县| 大田县| 正安县| 牟定县| 鹤壁市| 驻马店市| 桓台县| 同心县| 布拖县| 沂源县| 唐山市| 彭州市| 长兴县| 梧州市| 阿勒泰市| 沁水县| 呼伦贝尔市| 西和县| 江阴市| 绥芬河市| 洛扎县| 广安市| 饶河县| 湄潭县| 五华县| 石棉县| 密云县| 武川县| 沈丘县|