392.判断子序列(Java)

目录

题目描述:

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

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

输入:

s = "abc", t = "ahbgdc"

输出:

true

  • 0 < = s . l e n g t h < = 100 0 <= s.length <= 100 0<=s.length<=100
  • 0 < = t . l e n g t h < = 1 0 4 0 <= t.length <= 10^4 0<=t.length<=104
  • 两个字符串都只由小写字符组成。

代码实现:

java 复制代码
public class Main{

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		String s = "b";
		String t = "abc";
		System.out.println(isSubsequence(s, t));//true
	}

	public static boolean isSubsequence(String s, String t) {
		// 判断s是否为t的子序列
		int len = s.length();// 子序列的长度
		int index = 0;// 匹配成功的位数
		if (len > 0) {// 防止子序列越界
			for (int i = 0; i < t.length(); i++) {
				char c = t.charAt(i);// 获取子序列中的每一个字符
				if (index == len) {
					break;// 防止越界
				}
				if (c == s.charAt(index)) {
					index++;// 如果当前子序列的字符与主串匹配,指针加一
				}
			}
		}
		return index == len;// 匹配成功位数 是否和 模式串长度一致
	}

}
相关推荐
BothSavage4 小时前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn4 小时前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法
人活一口气4 小时前
从JVM调优到MCP协议:Java全栈技术体系深度总结与企业级架构实践
java·spring boot
烬羽5 小时前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
NE_STOP5 小时前
Vibe Coding -- 完整项目案例实操
java
荣码6 小时前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂
java·python
SimonKing6 小时前
Google第三方授权登录
java·后端·程序员
明月光8186 小时前
从一行 @Builder 说起:重新拾起 Java 的 Lombok、注解与 Builder 模式
java
考虑考虑15 小时前
Mybatis实现批量插入
java·后端·mybatis
咖啡八杯16 小时前
GoF设计模式——中介者模式
java·后端·spring·设计模式