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

本题涉及到使用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;
    }
};
相关推荐
靠沿20 小时前
Java数据结构初阶——LinkedList
java·开发语言·数据结构
Elias不吃糖21 小时前
LeetCode每日一练(209, 167)
数据结构·c++·算法·leetcode
铁手飞鹰21 小时前
单链表(C语言,手撕)
数据结构·c++·算法·c·单链表
悦悦子a啊21 小时前
项目案例作业(选做):使用文件改造已有信息系统
java·开发语言·算法
小殊小殊21 小时前
【论文笔记】知识蒸馏的全面综述
人工智能·算法·机器学习
无限进步_21 小时前
C语言动态内存管理:掌握malloc、calloc、realloc和free的实战应用
c语言·开发语言·c++·git·算法·github·visual studio
hweiyu001 天前
数据结构:循环链表
数据结构·链表
im_AMBER1 天前
AI井字棋项目开发笔记
前端·笔记·学习·算法
Wadli1 天前
项目2 |内存池1|基于哈希桶的多种定长内存池
算法
TT哇1 天前
【BFS 解决拓扑排序】3. ⽕星词典(hard)
redis·算法·宽度优先