华为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%内容,订阅专栏后可继续查看/也可单篇购买

华为OD机试刷题 文章被收录于专栏

华为OD机试刷题记录机考算法题库,帮助你上岸华为。提供C++/Java、JavaScript、Python四种语言的解法。

全部评论
双指针
点赞
送花
回复 分享
发布于 2023-12-13 20:20 江苏
这里有个问题,输出描述这里是说S的最后一位有效字符,并没要求S是有效子序列。
点赞
送花
回复 分享
发布于 05-28 16:53 北京
国泰君安
校招火热招聘中
官网直投

相关推荐

1.面5.13######松鼠ai一面###1.讲述一下你部署k8s集群项目的过程2.ansible是基于Python什么的加密模块,使用什么基本协议3.如何在服务器之间建立免密通道?有什么参数的配置ssh服务里面配置 登录配置&nbsp;端口配置&nbsp;认证配置&nbsp;看&nbsp;/etc/ssh/sshd.conf4.了解过nfs服务吗,如何搭建,怎么修改配置?5.nfs使用的是什么端口?,用来用过什么更高级的配置?nfs&nbsp;和&nbsp;portmapper两个服务是固定端口的,nfs为2049,portmapper为1116.怎么搭建k8s节点7.k8s的master的基本组件?8.如何将pod固定调度到自己的节点上?&nbsp;&nbsp;可以将pod的四大调度算法9.nginx-pod有做过什么特殊的配置吗?10.探针的类型?探针之间的区别?11.探针优先级的区别?startup&nbsp;liveness-probe&nbsp;readiness-probe12.三种探针检测发现pod没有存活,分别会启动什么策略?13.负载均衡池叫什么?service&nbsp;具体的模式14.了解过endpoint?15.你对k8s有什么的更高的流转?整个流量的流转的过程?(具体的过程)16.nodeport服务的模式具体将流量的过程?17.讲一下CICD的具体流程?18.你写过什么dockerfile&nbsp;吗?19.介绍一下你的mysql的集群?20.半同步和全同步之间的区别?21.mysql&nbsp;有什么使用什么的中间件?22.keepalived是如何配置?如何实现keepalived的高可用和负载均衡?23.tcpdump如何抓包vrrp协议的报文?vrrp的端口是什么?24.怎么查看mysql主从的状态?25.怎么统计机器上面的80端口?接管道符号之间26.你的主要的开发语言?27.你想走什么运维还是开发方向?28.怎么进行服务器性能之间的监控和排查故障?29.讲一下dns域名解析的过程?使用的是什么端口和协议30.了解过vpn的搭建模块?31.讲解一下nginx基本模块?(至少5)32.讲一下limit模块?如何进行限制,限制了什么?33.手撕代码?&nbsp;&nbsp;&nbsp;1.排序归并&nbsp;(没怎么练习没写出来)&nbsp;&nbsp;&nbsp;2.在shell里面连续50个创建用户2.面5.13忘记做记录了
查看33道真题和解析
点赞 评论 收藏
分享
2 4 评论
分享
牛客网
牛客企业服务