首先碰到求两字符串最长公共连续子串的问题,然后想到原先做过的求两字符串最长公共子序列问题,所以又把算法导论上的解法看了一下。
这两个问题是不同的问题,求最长公共子序列不要求求得的子字符串时连续的,比如说ACB和AB的最长公共子序列就是AB。而最长公共连续子串,要求求得的子串在两个字符串中必须是连续出现的,还是ACB和AB他们的最长公共子串是A或者是B。这里说的是求两字符串的最长公共子序列,用的是动态规划。
动态规划求解最优化问题应该具备的两个要素:最优化子结构和子问题重叠。我的理解就是碰到问题先看看能不能把大问题化解为小问题解决,这就是我对最优子结构的理解。子问题重叠意思就是说,你在求子问题的时候一些工作是重复做了,看看能不能想办法避免以下。
对于动态规划的运用我还不是很熟练,但我在碰到问题时往往是这样做的:先判断原先的问题能不能化解为小问题,如果能化为小问题的话,怎么求解,试着写一下(递推)公式。如果递推公式写成功了的话,恰巧符合动态规划求解。自然而然就可以应用动态规划了。动态规划的应用最主要的就是写出递推公式。
下面言归正传,求两个字符串的最长公共子序列。借用算法导论上的表示方法,给定一个字符串X=<x_1,x_2,...,x_m>(下划线后面的数字表示下标