【dp】leetcode 115. Distinct Subsequences

来源:互联网 发布:国内免费php空间 编辑:程序博客网 时间:2024/06/05 20:55

【dp】leetcode 115. Distinct Subsequences


dp  与公共子串匹配的算法思想类似


当当前字符s与t匹配时,次数dp[i][j] 可以采用两种方式进行计算,1)s[j]与t[i]匹配 为 dp[i-1][j-1]     2)  不考虑新加入的字符 s[j] ,为dp[i][j-1].   两种情况相加就可以得到了



public class Solution {    public int numDistinct(String s, String t) {    int[][] dp = new int[t.length()+1][s.length()+1];    for(int j=0;j<=s.length();j++){    dp[0][j] = 1;    }    for(int i=1;i<=t.length();i++){    for(int j=1;j<=s.length();j++){    if(s.charAt(j-1)==t.charAt(i-1)){    dp[i][j] = dp[i-1][j-1] + dp[i][j-1];    }else{    dp[i][j] = dp[i][j-1];    }    }    }    return dp[t.length()][s.length()];    }}


原创粉丝点击