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

本文详细解析LeetCode第392题“判断子序列”的三种解法:动态规划、简单遍历及利用Java内置函数IndexOf。通过具体代码示例,深入探讨每种方法的实现细节和效率对比。

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;
    }
}
内容概要:本文档是一份关于交换路由配置的学习笔记,系统地介绍了网络设备的远程管理、交换机与路由器的核心配置技术。内容涵盖Telnet、SSH、Console三种远程控制方式的配置方法;详细讲解了VLAN划分原理及Access、Trunk、Hybrid端口的工作机制,以及端口镜像、端口汇聚、端口隔离等交换技术;深入解析了STP、MSTP、RSTP生成树协议的作用与配置步骤;在路由部分,涵盖了IP地址配置、DHCP服务部署(接口池与全局池)、NAT转换(静态与动态)、静态路由、RIP与OSPF动态路由协议的配置,并介绍了策略路由和ACL访问控制列表的应用;最后简要说明了华为防火墙的安全区域划分与基本安全策略配置。; 适合人群:具备一定网络基础知识,从事网络工程、运维或相关技术岗位1-3年的技术人员,以及准备参加HCIA/CCNA等认证考试的学习者。; 使用场景及目标:①掌握企业网络中常见的交换与路由配置技能,提升实际操作能力;②理解VLAN、STP、OSPF、NAT、ACL等核心技术原理并能独立完成中小型网络搭建与调试;③通过命令示例熟悉华为设备CLI配置逻辑,为项目实施和故障排查提供参考。; 阅读建议:此笔记以实用配置为主,建议结合模拟器(如eNSP或Packet Tracer)动手实践每一条命令,对照拓扑理解数据流向,重点关注VLAN间通信、路由选择机制、安全策略控制等关键环节,并注意不同设备型号间的命令差异。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值