华为OD统一考试 -字符串序列判定

题目描述

输入两个字符串 S 和 L ,都只包含英文小写字母。S长度 ≤ 100,L长度 ≤ 500,000。判定S是否是L的有效子串。

判定规则:S 中的每个字符在 L 中都能找到(可以不连续),且 S 在L中字符的前后顺序与 S 中顺序要保持一致。(例如,S = ”ace” 是 L= ”abcde” 的一个子序列且有效字符是a、c、e,而”aec”不是有效子序列,且有效字符只有a、e)

输入描述

输入两个字符串 S 和 L,都只包含英文小写字母。S长度 ≤ 100,L长度 ≤ 500,000。

先输入S,再输入L,每个字符串占一行。

输出描述

S 串最后一个有效字符在 L 中的位置。(首位从0开始计算,无有效字符返回-1)

用例

输入

ace

abcde

输出

4

说明

输入

fgh

abcde

输出

-1

说明

题目解析

本题可以利用双指针来解决。

定义两个指针 i , j,分别指向S,L 字符串的索引0位置,

  • 当 S[i] 和 L[j] 的字符相同时,则 i++ 且 j++
  • 当 S[i] 和 L[j] 的字符不同时,则仅 j++

当 i ≥ S.length || J ≥ l.le

剩余60%内容,订阅专栏后可继续查看/也可单篇购买

2024华为OD机试卷题 文章被收录于专栏

本专栏给大家提供了华为2024最新华为OD 题目汇总。华为OD机试刷题记录机考算法题库,帮助你上岸华为。提供C++/Java、JavaScript、Python四种语言的解法。

全部评论
点赞 回复 分享
发布于 2024-09-21 10:20 四川

相关推荐

评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务