华为OD机试统一考试D卷C卷 - 字符串序列判定/最后一个有效字符( C++ Java JavaScript python C语言)

CSDN 2024-07-10 10:05:02 阅读 85

华为OD机考:OD统一考试D卷+C卷+A卷+B卷+刷题OJ

真题目录:真题目录(D卷 + C卷 + B卷 + A卷) + 考点说明

必刷专栏:最新2024华为OD机试(Java/JS/Py/C/C++)+ OJ

在线OJ :点击立即刷题,模拟真实机考环境

华为OD面试真题精选:华为OD面试真题精选

题目描述:字符串序列判定/最后一个有效字符(本题分值100)

输入两个字符串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)

用例

用例1

输入

<code>ace

abcde

输出

4

用例2

输入

fgh

abcde

输出

-1

解题思路

注意: 本题在C卷中和B卷中都有。机考可能会存在变形,请注意审题

在这里插入图片描述

我们初始化两个指针i和j,分别用于遍历S和L。

接下来,我们使用双指针法进行遍历,当i小于S的长度且j小于L的长度时,进行循环。

在循环中,我们判断S中的当前字符是否与L中的当前字符相等,如果相等,则将i指针向后移动一位。

无论字符是否相等,我们都将j指针向后移动一位。

当循环结束后,我们判断i是否等于S的长度,如果等于,则说明S的所有字符都在L中找到了,打印L中最后一个有效字符的位置(即j的值减1);否则,说明S还有字符没有在L中找到,打印-1。

最后,我们得到了S串最后一个有效字符在L中的位置。

用例解析

在上面的用例中,indexS和indexL是通过循环逐步变化的。下面是它们的具体变化过程&#



声明

本文内容仅代表作者观点,或转载于其他网站,本站不以此文作为商业用途
如有涉及侵权,请联系本站进行删除
转载本站原创文章,请注明来源及作者。