LeetCola_392_判断子序列_0727S

public boolean isSubsequence(String s, String t) {

for(char c : s.toCharArray())比 s.charAt(i)快

判断子序列

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

 intindexOf(int ch)
          返回指定字符在此字符串中第一次出现处的索引。
 intindexOf(int ch, int fromIndex)
          返回在此字符串中第一次出现指定字符处的索引,从指定的索引开始搜索。
charcharAt(int index)
          返回指定索引处的 char 值。
char[]toCharArray()
          将此字符串转换为一个新的字符数组。
  • 对于要匹配的短字符串,遍历每一个字符,
  • 不断地寻找该字符在长字符串中的位置,然后将位置更新,寻找下一个字符,相当于在长字符串上“跳跃”。
  • 如果下一个位置为 -1,表示长字符串再没有该字符了,返回 false 即可。
  • 如果能正常遍历完毕,则表示可行,返回 true.

 

 

双指针

  • 我们初始化两个指针 i 和 j,分别指向 s 和 t 的初始位置。
  • 每次贪心地匹配,匹配成功则 i 和 j同时右移,匹配 s 的下一个位置,
  • 匹配失败则 j 右移,i 不变,尝试用 t 的下一个字符匹配 s。
  • 最终如果 i 移动到 s 的末尾,就说明 s 是 t 的子序列。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值