美文网首页半栈工程师程序员
POJ 1458 Common Subsequence 最长公共

POJ 1458 Common Subsequence 最长公共

作者: TinyDolphin | 来源:发表于2017-11-22 17:11 被阅读0次

题意:给出两个字符串,求出最长的公共子序列的长度

Q:什么是公共子序列?

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

LCS 算法轨迹图


来自算法导论
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: 为什么这个数组每次使用都不需要清空?
     * A: 因为数组最上边的一行全部为 0 && 最左边的一列也全部为 0 ,
     *   而后续的值都是根据这一行一列来定值的。
     */
    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();
    }
}

相关文章

  • Poj 1458 Common Subsequence

    Poj 1458 Common Subsequence 题目 最长公共子序列问题。两个字符串,一个为目标串(如第一...

  • POJ 1458 Common Subsequence 最长公共

    题意:给出两个字符串,求出最长的公共子序列的长度 Q:什么是公共子序列?A:子序列中的每个字符都能在两个原串中找到...

  • LeetCode #1143 Longest Common Su

    1143 Longest Common Subsequence 最长公共子序列 Description:Given...

  • 最长公共子序列

    最长公共子序列问题( Longest Common Subsequence problem,LCS) 是求两个给定...

  • 最长公共子序列

    最长公共子序列(Longest Common Subsequence,简称 LCS)是非常经典的动态规划题目。通常...

  • 最长公共子序列问题

    最长公共子序列,英文缩写为LCS(Longest Common Subsequence)。其定义是,一个序列 S ...

  • 最长公共子序列

    1、定义 最长公共子序列,英文缩写为LCS(Longest Common Subsequence)。其定义是,一个...

  • LCS详解

    LCS是什么 LCS是Longest Common Subsequence的缩写,即最长公共子序列。一个序列,如果...

  • LCS解析,打印最大长度和路径

    LCS是什么 LCS是Longest Common Subsequence的缩写,即最长公共子序列。它与子串的区别...

  • LCS

    LCS(Longest Common Subsequence) 最长公共子序列 一个序列S任意删除若干个字符得到的...

网友评论

    本文标题:POJ 1458 Common Subsequence 最长公共

    本文链接:https://www.haomeiwen.com/subject/vprovxtx.html