题解 | #kmp算法#

kmp算法

http://www.nowcoder.com/practice/bb1615c381cc4237919d1aa448083bcc

思路:

题目的主要信息:

  • 在文本串T中找到模板串S出现的次数
  • S不为空
  • 要求时间空间最多为

方法一:暴力法(不会超时,但不符合要求)
具体做法:
遍历文本串,每次截取下标后m个与文本串比较,如果相同则答案加一。需要注意后面要留出m位防止访问越界。

class Solution {
public:
    int kmp(string S, string T) {
        int n = T.length();
        int m = S.length();
        int res = 0;
        for(int i = 0; i <= n - m; i++){ //遍历文本串
            if(T.substr(i, m) == S)  //找到字串
                res++;
        }
        return res;
    }
};

复杂度分析:

  • 时间复杂度:,遍历为,比较每次为
  • 空间复杂度:,无额外空间使用

方法二:KMP思想
字符串的字串匹配算法要优化,我们可以想到KMP算法。
具体做法:
像KMP算法一样,构建一个next数组,next[i]表示模式串S中最长公共前缀后缀的前缀结束的下标,从-1开始。
图片说明
匹配的时候,若是匹配成功,则两个字符串同步前进,若是匹配失败则继续往前搜索到next数组中的位置,若是完全匹配,跳到当前字串起始位置后一个,更新到next的最后一个匹配值,重新匹配下一个字串。
图片说明

class Solution {
public:
    int kmp(string S, string T) {
        int n = T.length();
        int m = S.length();
        int res = 0;
        vector<int> next(m + 1); 
        next[0] = -1;  //next数组从-1开始
        int k = -1;
        for(int i = 0; i < m;){  //初始化next数组
            if(k == -1 || S[k] == S[i]){
                k++;
                i++;
                next[i] = k;
            }
            else
                k = next[k];
        }
        k = 0;  //每次next数组从0开始,后面访问都会+1
        for(int i = 0; i < n;){
            if(k == -1 || T[i] == S[k]) {//若是匹配,k 与 i 一同加
                k++;
                i++;
                if(k == m){ //找到一个,将k置为next最大值
                    res++;
                    k = next[k];
                }
            }
            else  //否则继续往前搜索
                k = next[k];
        }
        return res;
    }
};

复杂度分析:

  • 时间复杂度:,不管初始化next数组,还是匹配字串都是一次遍历
  • 空间复杂度:,next数组的空间,
孤帆远影碧空尽 文章被收录于专栏

牛客网各类题单题解~

全部评论

相关推荐

1 收藏 评论
分享
正在热议
# 牛客帮帮团来啦!有问必答 #
1152266次浏览 17151人参与
# 通信和硬件还有转码的必要吗 #
11210次浏览 101人参与
# 不去互联网可以去金融科技 #
20525次浏览 258人参与
# 和牛牛一起刷题打卡 #
19040次浏览 1635人参与
# 实习与准备秋招该如何平衡 #
203445次浏览 3627人参与
# 大厂无回复,继续等待还是奔赴小厂 #
4983次浏览 31人参与
# OPPO开奖 #
19239次浏览 267人参与
# 通信硬件薪资爆料 #
265971次浏览 2484人参与
# 国企是理工四大天坑的最好选择吗 #
2230次浏览 34人参与
# 互联网公司评价 #
97720次浏览 1280人参与
# 简历无回复,你会继续海投还是优化再投? #
25039次浏览 354人参与
# 0offer是寒冬太冷还是我太菜 #
454923次浏览 5124人参与
# 国企和大厂硬件兄弟怎么选? #
53924次浏览 1013人参与
# 参加过提前批的机械人,你们还参加秋招么 #
14647次浏览 349人参与
# 硬件人的简历怎么写 #
82290次浏览 852人参与
# 面试被问第一学历差时该怎么回答 #
19405次浏览 213人参与
# 你见过最离谱的招聘要求是什么? #
28264次浏览 248人参与
# 学历对求职的影响 #
161259次浏览 1804人参与
# 你收到了团子的OC了吗 #
538790次浏览 6388人参与
# 你已经投递多少份简历了 #
344284次浏览 4963人参与
# 实习生应该准时下班吗 #
96990次浏览 722人参与
# 听劝,我这个简历该怎么改? #
63527次浏览 622人参与
牛客网
牛客企业服务