华为OD机试 - 字符串序列判定- C卷

该博客介绍了一道华为在线测评(OD)的算法题,要求判断字符串S是否为字符串L的有效子序列。有效子序列需满足S的所有字符在L中找到并保持相同顺序。解题思路包括从L中查找S的第一个字符开始,依次检查后续字符是否存在。给出的示例展示了如何根据给定的输入输出有效位置或-1。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述

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

示例二

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

dijkstra2023

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值