题解 | #最长公共子序列(二)#

最长公共子序列(二)

https://www.nowcoder.com/practice/6d29638c85bb4ffd80c020fe244baf11

import java.util.*;


public class Solution {
    /**
     * longest common subsequence
     * @param s1 string字符串 the string
     * @param s2 string字符串 the string
     * @return string字符串
     */
    public static String LCS(String s1, String s2) {
        int m = s1.length();
        int n = s2.length();
        //int[][] dp = new int[m+1][n+1];
        String[][] s = new String[m + 1][n + 1];
        for (int i = 0; i <= n; i++) {
            s[0][i] = " ";
        }
        for (int i = 0; i <= m; i++) {
            s[i][0] = " ";
        }
        for (int i = 1; i <= m; i++) {
            for (int j = 1; j <= n; j++) {
                if (s1.charAt(i - 1) == s2.charAt(j - 1)) {
                    //dp[i][j] = dp[i - 1][j - 1] + 1;
                    s[i][j] = s[i - 1][j - 1].concat(String.valueOf(s1.charAt(i - 1)));
                } else {
                    //dp[i][j] = Math.max(dp[i - 1][j],dp[i][j - 1]);
                    s[i][j] = s[i - 1][j].length() > s[i][j - 1].length() ? s[i - 1][j] : s[i][j -
                              1];
                }
            }
        }
        if (s[m][n].equals(" "))
            return "-1";
        return s[m][n].trim();
    }
}

基本上和一差不多

全部评论

相关推荐

点赞 收藏 评论
分享
牛客网
牛客企业服务