最新华为上机考试
真题目录:点击查看目录
华为OD面试真题精选:点击立即查看
2025华为od机试2025C卷-华为OD上机考试2025年C卷
题目描述:字符串序列判定/最后一个有效字符(本题分值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
输入
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是通过循环逐步变化的。下面是它们的具体变化过程:
-
初始化索引:
indexS = 0, indexL = 0

这篇博客主要介绍了华为OD机试中的一道题目——字符串序列判定,包括问题描述、输入输出要求、解题思路及代码实现。通过双指针法遍历字符串,判断给定的子串S是否为长串L的有效子序列,并找出S中最后一个有效字符在L中的位置。
订阅专栏 解锁全文
8327

被折叠的 条评论
为什么被折叠?



