华为OD机试统一考试D卷C卷 - 字符串序列判定

输入两个字符串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是通过循环逐步变化的。下面是它们的具体变化过程:

  1. 初始化索引:indexS = 0, indexL = 0
  2. 第一次循环:检查S中的第一个字符'a'与L中的第一个字符'a'是否相同,相同则indexS加1,indexL加1。indexS = 1, indexL = 1
  3. 第二次循环:检查S中的第二个字符'c'与L中的第二个字符'b'是否相同,不同则inde

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

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

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

全部评论
双指针
点赞 回复 分享
发布于 2023-12-13 20:20 江苏
这里有个问题,输出描述这里是说S的最后一位有效字符,并没要求S是有效子序列。
点赞 回复 分享
发布于 05-28 16:53 北京
信也科技
校招火热招聘中
官网直投
mk if(j==n) //注意是n不是n-1
点赞 回复 分享
发布于 09-19 21:26 四川

相关推荐

#当你面对裁员会如何?#面对裁员,每个人的感受都是独特而深刻的。有的人可能会因为得到了一笔相对可观的经济补偿而感到一丝宽慰,认为这是一个“重新开始”的机会,可以借此机会探索新的职业道路,或是投入更多的时间和精力在个人兴趣和发展上。然而,这种“喜提N+1”的心态背后,往往也隐藏着对未来的不确定性和对未知挑战的隐忧。而更多的人,在接到裁员通知的那一刻,可能会感到震惊、失落、无助甚至愤怒。他们可能会担心自己的经济状况,特别是对于那些家庭负担较重或经济储备不足的人来说,失去工作意味着失去了稳定的收入来源,生活的各个方面都可能受到影响。同时,他们也会担忧自己的职业前景,担心自己在就业市场上失去竞争力,难以找到新的工作机会。这种焦虑和不安情绪可能会持续一段时间,甚至影响到个人的身心健康和社交关系。因此,当我们谈论裁员时,除了关注经济补偿等实际问题外,更应该关注被裁员工的情感需求和心理健康。公司和社会应该为被裁员工提供更多的支持和帮助,如心理咨询、职业指导、技能培训等,帮助他们更好地应对裁员带来的挑战和压力。同时,我们也应该鼓励被裁员工保持积极的心态,相信自己有能力克服困难,重新找到属于自己的职业道路和生活节奏。
点赞 评论 收藏
分享
4 4 评论
分享
牛客网
牛客企业服务