LeetCode 面试经典150题 392.判断子序列

题目

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

字符串的一个子序列是原始字符串删除一些(也可以不删除)字符而不改变剩余字符相对位置形成的新字符串。(例如,"ace""abcde"的一个子序列,而"aec"不是)。

思路

代码

java 复制代码
class Solution {
    public boolean isSubsequence(String s, String t) {
        // 判断s是否为t的子序列
        if (s.length() == 0) return true;
        for (int i = 0, j = 0; j < t.length(); j++) {
            if (s.charAt(i) == t.charAt(j)) {
                // 若已经遍历完 s ,则提前返回 true
                if (++i == s.length())
                    return true;
            }
        }    
        return false;
    }
}

性能:时间复杂度O(t) 空间复杂度O(1)

相关推荐
荣光属于凯撒16 小时前
P3040 [USACO12JAN] Bale Share S
算法·深度优先
kingcjh9716 小时前
十、RL 算法性能调优指南
深度学习·算法
muls116 小时前
java面试宝典
java·linux·服务器·网络·算法·操作系统
kyriewen16 小时前
MutationObserver:DOM界的“卧底”,暗中观察每个风吹草动
前端·javascript·面试
BieberChen16 小时前
匈牙利匹配算法 (Hungarian Algorithm) 详解
算法
春栀怡铃声16 小时前
常考排序的梳理
数据结构·算法·排序算法
第二只羽毛16 小时前
第六章 图
大数据·数据结构·算法·深度优先·图论·广度优先·宽度优先
xlp666hub17 小时前
一篇文章让你彻底区分#define和typedef
面试
星辰_mya17 小时前
数据库运维与数据安全:备份恢复、日志分析与故障排查
运维·数据库·后端·面试·架构师
csuzhucong17 小时前
puzzle(1052)仙人指路
算法