两句闲话 得到两个序列的最长公共子序列(LCS)是个经典问题,使用动态规划,实现起来并不难. 一般来说,我们只是输出一个LCS.但是,老师布置的作业是输出所有的LCS. 解法 按照一般的方法,我们首先得到一个矩阵,然后从矩阵的右下角开始回溯.回溯时,我们选择较大的数字,以向左,或向上,或向左上.但当数字相等时,我们往往会随便向某一个方向回溯,这样的话,我们就只会得到一个LCS.因此,很容易想到,所有的LCS会构成一棵树,我们只需要对这棵树进行先序遍历,就可得到所有的LCS. 代码如下 #pyth