POJ 1458 Common Subsequence 最長公共子序列(LCS)

題意:給出兩個字符串,求出最長的公共子序列的長度

Q:什么是公共子序列?

A:子序列中的每個字符都能在兩個原串中找到,而且每個字符的先后順序和原串中的先后順序一致。

LCS 算法軌跡圖


來自算法導(dǎo)論
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.util.Scanner;

public class Main {

    /**
     * Q: 為什么這個數(shù)組每次使用都不需要清空?
     * A: 因為數(shù)組最上邊的一行全部為 0 && 最左邊的一列也全部為 0 ,
     *   而后續(xù)的值都是根據(jù)這一行一列來定值的。
     */
    private static int[][] maxLen = new int[1000][1000];

    private static int work(String str, String str2) {
        char[] ch = str.toCharArray();
        char[] ch2 = str2.toCharArray();
        int length = ch.length;
        int length2 = ch2.length;
        for (int i = 1; i <= length; i++) {
            for (int j = 1; j <= length2; j++) {
                if (ch[i - 1] == ch2[j - 1]) {
                    maxLen[i][j] = maxLen[i - 1][j - 1] + 1;
                } else {
                    maxLen[i][j] = Math.max(maxLen[i][j - 1], maxLen[i - 1][j]);
                }
            }
        }
        return maxLen[length][length2];
    }

    public static void main(String[] args) {
        Scanner in = new Scanner(new BufferedReader(new InputStreamReader(System.in)));
        PrintWriter out = new PrintWriter(new BufferedWriter(new OutputStreamWriter(System.out)));
        String inputStr;
        String inputStr2;
        while (in.hasNext()) {
            inputStr = in.next();
            inputStr2 = in.next();
            out.println(work(inputStr, inputStr2));
        }
        out.flush();
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容