(C++)华为OD机考:统一考试 C卷 + D卷 + B卷 +A卷
目前在考C卷,经过两个月的收集整理,C卷真题已基本整理完毕
抽到原题的概率为2/3到3/3,也就是最少抽到两道原题。请注意:大家刷完C卷真题,最好要把B卷的真题刷一下,因为C卷的部分真题来自B卷。
另外订阅专栏还可以联系笔者开通在线OJ进行刷题,提高刷题效率。
真题目录:【C++题解】华为 OD 机试 C卷抽中题库清单(全真题库)含考点说明以及在线OJ
专栏:(C++) 华为OD机试C卷+B卷 统一考试真题
华为OD面试真题精选:华为OD面试真题精选
在线OJ:点击立即刷题,模拟真实机考环境
题目描述:字符串序列判定/最后一个有效字符(本题分值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。