题目描述:给定两个序列X={x1, x2, x3, ...xm}和Y={y1, y2, y3, ... yn}, 求X和Y的最长公共子序列。
分析:如果采用暴力搜索的方法的话,需要穷举X的所有子序列然后分别和Y的所有子序列进行比较,从而筛选出LCS。X共有2^m个子序列,所以暴力搜索的话复杂度肯定是指数阶的,显然不实用。那我们能否通过X和Y的前缀子序列的结果分析推导出X和Y的子序列呢?
假设X的一个前缀子序列 Xi = {x1, x2, x3, ... , xi}, Y的一个前缀子序列Yi = {y1, y2, y3, ... , yi}, 并且我们假设已知Xi和Yi的LCS为kij。那么X(i+1)和Y(i+1)的LCS是多少呢?不妨假设其LCS为k(i+1)(j+1)。稍加思考,容易发现有两种情况:(1) 如果X(i+1) = Y(i+1), 那么显然k(i+1)(j+1) = kij + 1 (2)如果X(i+1) != Y(i+1), 那么k(i+1)(j+1) = max(k(i+1)j, ki(j+1)) 看到这里对动态规划有了解的同学通常会发现,这个好像有点符合动态规划的解题特征哎!下面我们就用动态规划的解题思路继续分析一下此题:
步骤一、子问题:要想求Xi和Yj的LCS,我们就必须先求出X(i-1)和Y(j-1)的LCS,X(i)和Y(j-1)的LCS以及X(i-1)和Y(j)的LCS,从而形成了一个递归问题