找出字符串中第一个匹配项的下标-力扣

本题涉及到使用kmp算法,对字符串进行模式匹配,kmp算法可以参考代码随想录-kmp算法

代码如下:

cpp 复制代码
class Solution {
public:
    int strStr(string haystack, string needle) {
        vector<int> next = getNext(needle);
        int j = 0;
        for(int i = 0; i < haystack.size(); i++){
            while(j > 0 && haystack[i] != needle[j]){
                j = next[j - 1];
            }

            if(haystack[i] == needle[j]){
                j++;
            }
            if(j == needle.size()){
                return i - needle.size() + 1;
            }
        } 

        return -1;
    }

    vector<int> getNext(string& s){
        int j = 0;
        vector<int> next(s.size());
        for(int i = 1; i < s.size(); i++){
            while(j > 0 && s[i] != s[j]){
                j = next[j - 1];
            }

            if(s[i] == s[j]){
                j++;
            }

            next[i] = j;
        }

        return next;
    }
};
相关推荐
埃伊蟹黄面10 分钟前
模拟算法思想
c++·算法·leetcode
副露のmagic16 分钟前
更弱智的算法学习day 10
python·学习·算法
hweiyu0017 分钟前
数据结构:邻接矩阵
数据结构
逸风尊者24 分钟前
开发可掌握的知识:uber H3网格
后端·算法
半问37 分钟前
付费投流硬控互联网
人工智能·算法·互联网·推荐·流量
西岸行者40 分钟前
学习Hammerstein-Wiener 模型,以及在回声消除场景中的应用
人工智能·学习·算法
夏乌_Wx1 小时前
练题100天——DAY24:罗马数字转整数+环形链表+大小端判断
算法
youngee111 小时前
hot100-48腐烂的橘子
算法
Fine姐1 小时前
数据结构01——栈
数据结构
hweiyu001 小时前
数据结构:有向无环图
数据结构