麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

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

poj 1458 最長公共子序列

2019-11-11 05:14:08
字體:
來源:轉載
供稿:網友

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[i][j] 是在i的當前字符,和j的當前字符相對于前面 1~i-1 1~j-1里面最長的公共子序列。 因為題目要求的公共子序列的兩個條件是 在s里面是有次序的,在s2里面也是有次序,過了的不能再被選擇,只能不斷往后選。相當于兩個上升序列合并,但是選擇條件改變了。而那些不相同的 保持的是上一個相同的最大值。 遇到兩個相同的值,dp[i][j] 由s的上一個字符階段 i-1 里面選擇 j在1~j-1字符里面的最長公共序列里面選擇最長的dp,由于j-1是j在 1到j-1里面最長的 所以 dp[i-1][j-1]是上一個相同字符里面最長的。 為什么j-1 是1~j-1里面最長的 因為 dp[i][j] =max(dp[i-1][j],dp[i-1][j-1]),從而得到無論是i的上一階段還是當前階段i也是最長的,而且 與(1~j-1)也是最長的那個。 if(s[i]==s2[j]) dp[i][j]=dp[i-1][j-1]+1; else { dp[i][j] = max(dp[i-1][j],dp[i][j-1]);}

#include <cstdio>#include <iostream>#include <cstring>using namespace std;int dp[1001][1001];char s[1001];char s1[1001];//if(s[i]==s2[j]) dp[i][j]=dp[i-1][j-1]+1;//dp[i][j]=max(dp[i-1][j],dp[i][j-1]);int main(){ while(scanf("%s %s",s+1,s1+1)!=EOF) { memset(dp,0,sizeof(dp)); dp[0][0]=0; int len1=strlen(s+1); int len2=strlen(s1+1); for(int i=1;i<=len1;i++) { for(int j=1;j<=len2;j++) { if(s[i]==s1[j]) { dp[i][j]=dp[i-1][j-1]+1; } else { dp[i][j]=max(dp[i-1][j],dp[i][j-1]); } } } printf("%d/n",dp[len1][len2] ); }}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 97porn| 欧美日韩免费一区二区三区 | 国产999精品久久久久 | 激情亚洲一区二区 | 欧美a∨亚洲欧美亚洲 | 91精品观看91久久久久久国产 | 久久久精品福利 | 久久精品中文字幕 | 欧美成人精品一区 | 久久久久久久久久久国产精品 | 精品一区二区久久久久久久网精 | 日韩视频在线一区二区三区 | 午夜精品小视频 | 黄色毛片视频在线观看 | 国产精品久久久久久影视 | 国产91精品一区二区麻豆亚洲 | 亚洲精品动漫在线观看 | 久久精品亚洲精品国产欧美kt∨ | 美女露100%无遮挡 | 久久网站热最新地址 | 成人激情视频网 | 羞羞草视频 | 日韩激情一区 | 毛片一区二区三区四区 | 成人免费毛片一 | 欧美视频一二区 | 午夜视频在线看 | 免费黄色小网站 | 一级网站| 成人在线观看免费观看 | 婷婷一区二区三区四区 | 精品国产看高清国产毛片 | 黄色毛片免费视频 | 国产黄色网 | 欧美a视频在线观看 | 久久国产精品久久精品国产演员表 | 男女生羞羞视频网站在线观看 | 欧洲色阁中文字幕 | a一级黄 | 看免费一级毛片 | 久久福利小视频 |