子序列简单 LeetCode392. 判断子序列

392. 判断子序列

描述

给定字符串 s 和 t ,判断 s 是否为 t 的子序列。

双指针
class Solution {
    public boolean isSubsequence(String s, String t) {
        int i = 0, j = 0;
        while(i != s.length() && j != t.length()){
            if(s.charAt(i) == t.charAt(j)){
                i++;
            }
            j++;
        }
        if(i == s.length()){
            return true;
        }
        return false;
    }
}
动态规划

利用两个数组最长公共子序列的解法,当两个数组最长公共子序列的长度等于s的长度时,说明t中存在s这样的子序列。

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

你可能感兴趣的:(动态规划)