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

OD统一考试(D卷)

分值: 100分

题解: Java / Python / C++

华为od真题

题目描述

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

题解

这道题目的主要思路是遍历字符串L,在遍历的过程中,逐一比较L中的字符和S中的字符是否相等。如果相等,则S的索引前进一步,直到S的索引达到S的长度。在这个过程中,记录每次匹配成功时L中的索引位置。最后输出最后一个有效字符在L中的位置。

这种方法的时间复杂度是O(n),其中n是字符串L的长度。因为每个字符只需要遍历一次。

注意,这个题目并不要求S在L中是连续的子串,只需要保持相对顺序一致即可。

给定的代码是用Java实现的,也提供了Python和C++的实现。

在Python的代码中,使用了input()函数获取输入字符串。

在C++的代码中,使用了cin来获取输入。

这些代码的基本逻辑是相同的,只是语法上有些差异。

Java

import java.util.Scanner;
/**
 * @author code5bug
 */
public class Main {

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String s = sc.nextLine(), t = sc.nextLine();

        int n1 = s.length(), n2 = t.length();
        int i = 0, ans = -1;
        for (int j = 0; j < n2; j++) {
            if (s.charAt(i) == t.charAt(j)) {
                if (++i == n1) {
                    ans = j;
                    break;
                }
            }
        }

        System.out.println(ans);
    }
}
// AC 60%

输出描述

S串最后一个有效字符在L中的位置。

import java.util.Scanner;
/**
 * @author code5bug
 */
public class Main {

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String s = sc.nextLine(), t = sc.nextLine();

        int n1 = s.length(), n2 = t.length();
        int i = 0, ans = -1;
        for (int j = 0; i < n1 && j < n2; j++) {
            if (s.charAt(i) == t.charAt(j)) {
                ans = j;
                i++;
            }
        }

        System.out.println(ans);
    }
}
// AC

Python

S, L = input(), input()
n1, n2 = len(S), len(L)

i, j, ans = 0, 0,-1
while i < n1 and j < n2:
    if S[i] == L[j]:
        i += 1
        ans = j
    j += 1

print(ans)

C++

#include <iostream>
#include <string>

using namespace std;

int main() {
    string s,t;
    cin >> s >> t;
    int n1= s.size(), n2 = t.size();
    int i = 0, ans = -1;
    for(int j = 0; i < n1 && j < n2; j++) {
        if(s[i] == t[j]) {
            ans = j;
            i++;
        }
    }

    cout << ans << endl;

    return 0;
}

解不易, 如果有帮助到您,请给点个赞 ‍❤️‍ 和收藏 ⭐,让更多的人看到。🙏🙏🙏

#面经##秋招##华为od##华为od题库##校招#
全部评论
static int f(String s1, String s2){ if (s1.length() > s2.length()) return -1; char[] c1 = s1.toCharArray(); char[] c2 = s2.toCharArray(); int index = 0; for (int i = 0; i < c2.length; i++) { if (c2[i] == c1[index] && ++index == c1.length) return i; } return -1; }
1 回复 分享
发布于 2024-09-25 17:24 广西
@在巴厘岛游泳的小苹果
点赞 回复 分享
发布于 2024-07-30 18:30 广东
面经好评,看看我的offer选择吧。
点赞 回复 分享
发布于 2024-07-26 19:23 广西

相关推荐

03-18 01:22
门头沟学院 Java
肖先生~:先别说工资,现在有个工作就不错了
点赞 评论 收藏
分享
03-27 16:40
已编辑
门头沟学院 C++
26学院本太难了,很多公司机筛就给我刷了。机会都难拿到如果是简历存在问题也欢迎拷打————————————————————分割线——————————————————————2026.3.4更新:发完贴之后,时不时投递又收到了不少的笔试/面试邀请。主要是之前投递简历出去之后基本上都是沉默状态,年后好转了不少timeline:2026.01.21&nbsp;文远知行笔试,半年多没刷算法题&nbsp;-&gt;挂&nbsp;(后续HR说春招可以重新安排笔试)2026.2.4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;小鹏汇天&nbsp;技术一面,第二周收到结果&nbsp;-&gt;挂2026.2.12&nbsp;&nbsp;&nbsp;大众Cariad代招&nbsp;技术二面&nbsp;-&gt;Offer2026.2.28&nbsp;&nbsp;&nbsp;多益网络技术面试,由于风评太差,一直在犹豫要不要接面试&nbsp;-&gt;推迟-----------分割线-----------2026.3&nbsp;月前的某一天,临时去电网报名了二批计算机岗位的笔试2026.3.6&nbsp;从上家公司实习离职,氛围最好的一家公司,leader&nbsp;说可以帮忙转正,但是流程太长,而且我们部门据说只有一个&nbsp;hc,更想要研究生,我很有可能是会被签外包公司在这里干活,就离职了。2026.3.9&nbsp;入职新公司,大众Cariad&nbsp;以外部公司的身份进组,项目组签了三年,后续三年应该都可以在这里呆,不知道有没有希望原地跳槽。2026.3.10&nbsp;电网考试居然说我通过资格审查了,短信约我去参加资格审查,请假一天,买了&nbsp;12&nbsp;号晚上的机票回成都2026.3.15&nbsp;参加国家电网计算机类笔试2026.3.17&nbsp;电网出成绩了,感觉很低。觉得已经🈚️了2026.3.18&nbsp;收到电网面试通知,通知&nbsp;3.22-3.25&nbsp;这个时间去面试,我的岗位只招&nbsp;1&nbsp;个人。据说面试只有&nbsp;2-3&nbsp;人,不知道能不能成功----------分割线-----------2026.3.21&nbsp;电网面试结束,感觉回答的还勉勉强强,大概是2个岗位分别招1个人,一共11人面试,实际来了9人2026.3.27&nbsp;出面试成绩,满分100分,早上10:20左右发现面试成绩46,我震惊了,没截图,后面过了十分钟重新看发现面试成绩给我改成58了。但同样震惊。朋友问我是不是把面试官打了,哈哈
点赞 评论 收藏
分享
评论
7
2
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务