华为上机真题 2022字符串序列判定

Posted Linux猿

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了华为上机真题 2022字符串序列判定相关的知识,希望对你有一定的参考价值。

🎈 作者:Linux猿

🎈 简介:CSDN博客专家🏆,华为云享专家🏆,Linux、C/C++、云计算、物联网、面试、刷题、算法尽管咨询我,关注我,有问题私聊!

🎈 关注专栏: 数据结构和算法成神路【精讲】优质好文持续更新中……🚀🚀🚀

🎈 欢迎小伙伴们点赞👍、收藏⭐、留言💬


目录

一、题目描述

1.1 输入描述

1.2 输出描述

1.3 测试样例

1.3.1 示例 1

1.3.2 示例 2

二、解题思路

三、代码实现

四、时间复杂度


注意:题目来源于网络用户分享,本文仅分享做题思路和方法,如有侵权请联系我删除!

一、题目描述

输入两个字符串 S 和 L,都只包含英文小写字母,S 长度 <= 100, L 长度 < 500,000。判定 S 是否是 L 的有效子串。

字符串的一个有效子串是原始字符串删除一些(也可以不删除)字符而不改变剩余字符相对位置形成的新字符串。(例如,"ace" 是 "abcde" 的一个子序列,而"aec"不是)。

1.1 输入描述

输入两个字符串 S 和 L , S 长度 < 100, L 长度 <= 500,000。

1.2 输出描述

S 串最后一个有效字符在L中的位置(首位从 0 开始计算,无有效字符返回 -1)

1.3 测试样例

1.3.1 示例 1

输入

ace
abcde

输出

4

1.3.2 示例 2

输入

fgh
abcde

输出

-1


二、解题思路

本题可以用贪心的思路解决,初始化两个指针 i 和 j,分别指向 S 和 L 的初始位置。每次贪心地匹配,匹配成功则 i 和 j 同时右移,匹配 S 的下一个位置,匹配失败则 j 右移,i 的位置不变,尝试用 L 的下一个字符匹配 S。 最后如果 S 中的字符全部匹配完成,则表示 S 是 L 的子串,注意记录最后匹配字符的位置。

三、代码实现

代码实现如下所示。

#include <iostream>
using namespace std;


int isSubsequence(string s, string t) 
    int n = s.length(), m = t.length();
    int ans = -1;
    int i = 0, j = 0;
    while (i < n && j < m) 
        if (s[i] == t[j]) 
            i++;
            if (i == n) 
                ans = j;
                break;
            
        
        j++;
    
    return ans;


int main()

    string strS, strL;
    while (cin>>strS>>strL) 
        int ans = isSubsequence(strS, strL);
        cout<<ans<<endl;
    
    return 0;

四、时间复杂度

时间复杂度:O(n)

在上述代码中,n 表示字符串 L 的长度,需要遍历字符串 L 查找 S 是否是其子串,所以时间复杂度为 O(n)。


🎈 感觉有帮助记得「一键三连支持下哦!有问题可在评论区留言💬,感谢大家的一路支持!🤞猿哥将持续输出「优质文章」回馈大家!🤞🌹🌹🌹🌹🌹🌹🤞


以上是关于华为上机真题 2022字符串序列判定的主要内容,如果未能解决你的问题,请参考以下文章

华为上机真题 2022字符串分隔

华为上机真题 2022字符串排序

华为上机真题 2022字符串比较

华为上机真题 2022字符串加密

华为上机真题 2022字符串最后一个单词的长度

华为上机真题 2022一种字符串压缩表示的解压