leetcode(DP)--392. 判断子序列

leetcode(DP)–392. 判断子序列

1,题目:

在这里插入图片描述
2,思路:

方法一:动态规划:

思路:

状态:dp[i][j]为s的从头开始到i的子字符串是否为t从头开始到j的子字符串的子序列

状态转移公式:

  • 1、当char[i]==char[j]时,则字符i一定是j的子序列,如果0i-1子字符串是0j-1子字符串的子序列,则dp[i][j]=true,所以dp[i][j]= dp[i-1][j-1];
  • 2、当char[i]!=char[j]时,即判断当前0i子字符串是否是0j-1的子字符串的子序列,即dp[i][j] =dp[i][j -1](这里也就是移动j了,来找i对应的位置的元素和j-1时的位置的元素是否相等)。如ab,eabc,虽然s的最后一个字符和t中最后一个字符不相等,但是因为ab是eab的子序列,所以ab也是eabc的子序列
  • 3、初始化:空字符串一定是t的子字符串的子序列,所以dp[0][j]=true
  • 4、结果:返回dp[sLen][tLen]

方法二:简单方法(没有用动态规划):
就是遍历s和t,然后看t中是否有s,就是简单的遍历。

方法三:用到了自带的函数IndexOf:

java中非常好的一个方法,indexOf(char c,int m)意思是从第m位置开始寻找该索引,找到则返回该索引,否则返回-1,利用该特性我们通过对索引处理从而获得解

3,代码:

方法一:动态规划:

class Solution {
    public boolean isSubsequence(String s, String t) {

        /*动态规划:
        思路:

状态:dp[i][j]为s的从头开始到i的子字符串是否为t从头开始到j的子字符串的子序列

状态转移公式:

1、当char[i]==char[j]时,则字符i一定是j的子序列,如果0~i-1子字符串是0~j-1子字符串的子序列,则dp[i][j]=true,所以dp[i][j] = dp[i-1][j-1];
2、当char[i]!=char[j]时,即判断当前0~i子字符串是否是0~j-1的子字符串的子序列,即dp[i][j] = dp[i][j - 1](这里也就是移动j了,来找i对应的位置的元素和j-1时的位置的元素是否相等)。如ab,eabc,虽然s的最后一个字符和t中最后一个字符不相等,但是因为ab是eab的子序列,所以ab也是eabc的子序列
3、初始化:空字符串一定是t的子字符串的子序列,所以dp[0][j]=true
4、结果:返回dp[sLen][tLen]



        */
        int sLen = s.length(), tLen = t.length();
        if (sLen > tLen) return false;
        if (sLen == 0) return true;
        boolean[][] dp = new boolean[sLen + 1][tLen + 1];
        //初始化
        for (int j = 0; j < tLen; j++) {
            dp[0][j] = true;//空字符串一定是t的子字符串的子序列
        }
        //dp
        for (int i = 1; i <= sLen; i++) {
            for (int j = 1; j <= tLen; j++) {
                if (s.charAt(i - 1) == t.charAt(j - 1)) {
                    dp[i][j] = dp[i - 1][j - 1];//因为s.charAt(i - 1) == t.charAt(j - 1),所以分别移动i和j的指针,接着判断下一个i和j对应的元素值是否相等
                } else {
                    dp[i][j] = dp[i][j - 1];//这里是s.charAt(i - 1) != t.charAt(j - 1),所以移动j,i先不动,看看目前这个i对应的元素和j的下一个元素j-1的元素 是否相等
                }
            }
        }
        return dp[sLen][tLen];
    }
}

方法二:简单方法(没有用动态规划):

class Solution {
    public boolean isSubsequence(String s, String t) {
        int i = 0;
        for (char ch : s.toCharArray()) {
            while (i < t.length() && t.charAt(i) != ch) i++;
            i++;
        }
        return i <= t.length() ? true : false;
    }
}

方法三:用到了自带的函数IndexOf:

class Solution {
    public boolean isSubsequence(String s, String t) {
        /*
        java中非常好的一个方法,indexOf(char c,int m)意思是从第m位置开始寻找该索引,找到则返回该索引,否则返回-1,利用该特性我们通过对索引处理从而获得解。
        */
        char[] arr = s.toCharArray();
        int j = -1;
        for(int i = 0;i<arr.length;i++) {
            j = t.indexOf(arr[i],j+1);
            if(j==-1) {
                return false;
            }
        }
        return true;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值