Interleaving String

来源:互联网 发布:601519历史交易数据 编辑:程序博客网 时间:2024/04/19 17:17
    //two dimensions dp    public boolean isInterleave(String s1, String s2, String s3) {        // Start typing your Java solution below        // DO NOT write main() function        if(s1.length() + s2.length() != s3.length()) return false;        if(s1.length() == 0 && s2.length() == 0 && s3.length() == 0) return true;        boolean[][] dp = new boolean[s1.length() + 1][s2.length() + 1];        dp[0][0] = true;        for(int i = 1; i <= s1.length(); i++) {            if(s1.charAt(i - 1) == s3.charAt(i - 1) && dp[i - 1][0] == true) dp[i][0] = true;            else dp[i][0] = false;        }        for(int i = 1; i <= s2.length(); i++) {            if(s2.charAt(i - 1) == s3.charAt(i - 1) && dp[0][i - 1] == true) dp[0][i] = true;            else dp[0][i] = false;        }        for(int i = 1; i <= s1.length(); i++) {            for(int j = 1; j <= s2.length(); j++) {                if(dp[i - 1][j] == true) {                    if(s1.charAt(i - 1) == s3.charAt(i + j - 1)) dp[i][j] = true;                    else dp[i][j] = false;                }else if(dp[i][j - 1] == true) {                    if(s2.charAt(j - 1) == s3.charAt(i + j - 1)) dp[i][j] = true;                    else dp[i][j] = false;                }            }        }        return dp[s1.length()][s2.length()];    }

原创粉丝点击