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

本题涉及到使用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;
    }
};
相关推荐
数智工坊几秒前
【数据结构-树与二叉树】4.7 哈夫曼树
数据结构
!!!!8134 分钟前
蓝桥备赛Day1
数据结构·算法
Mr_Xuhhh4 分钟前
介绍一下ref
开发语言·c++·算法
七点半7704 分钟前
linux应用编程部分
数据结构
夏鹏今天学习了吗8 分钟前
【LeetCode热题100(99/100)】柱状图中最大的矩形
算法·leetcode·职场和发展
静听山水8 分钟前
Redis核心数据结构-Hash
数据结构·redis·哈希算法
啊阿狸不会拉杆14 分钟前
《机器学习导论》第 9 章-决策树
人工智能·python·算法·决策树·机器学习·数据挖掘·剪枝
Mr_Xuhhh15 分钟前
C++11实现线程池
开发语言·c++·算法
若水不如远方16 分钟前
分布式一致性(三):共识的黎明——Quorum 机制与 Basic Paxos
分布式·后端·算法
zhim0017 分钟前
数据结构笔记(上)(看这亿点就够了)
数据结构