最长公共子序列

最长公共子序列

http://www.nowcoder.com/questionTerminal/6d29638c85bb4ffd80c020fe244baf11

import java.util.*;


public class Solution {
    /**
     * longest common subsequence
     * @param s1 string字符串 the string
     * @param s2 string字符串 the string
     * @return string字符串
     */
    public String LCS (String s1, String s2) {
        int len1 = s1.length();
        int len2 = s2.length();
        char[] arr1 = s1.toCharArray();
        char[] arr2 = s2.toCharArray();
        int[][] dp = new int[len1 + 1][len2 + 1]; // s1前i子串与s2前j子串的最长公共子序列长度
        for (int i = 1; i < len1 + 1; i ++) {
            for (int j = 1; j < len2 + 1; j ++) {
                if (arr1[i-1] == arr2[j-1]) {
                    dp[i][j] = dp[i-1][j-1] + 1;
                } else { 
                    dp[i][j] = Math.max(dp[i-1][j], dp[i][j-1]);
                }
            }
        }
        // 反推子序列
        StringBuffer sb = new StringBuffer();
        for (int i = len1, j = len2; i >= 0 && j >= 0 && sb.length() < dp[len1][len2]; i --, j --) {
            while (dp[i][j-1] == dp[i][j]) {
                j --;
            }
            while (dp[i-1][j] == dp[i][j]) {
                i --;
            }
            sb.insert(0, arr1[i-1]);
        }
        if (sb.length() == 0) return "-1";
        return sb.toString();
    }
}
全部评论

相关推荐

10-15 10:23
门头沟学院 Java
牛可乐的头像真牛:赶紧举报,这公司绝对是诈骗的,等你签约后工作一两个月后根据合同漏洞把你开除,并且要求你赔偿3w培训费,996是为了提前筛选心甘情愿签下合同容易受骗的群体,纯粹面向校招生精心设计的骗局
你见过哪些工贼行为
点赞 评论 收藏
分享
10-09 19:08
已编辑
门头沟学院 Java
后端转测开第一人:换个模版 技术栈写的精炼紧凑一点 多投就行
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务