P8827传智杯子串

KMP的典型应用,就是个模板题

值得注意的是,这个题是不区分大小写的,最开始写了一直不对,开始怀疑是不是背错模板了,最后重新读了一遍题才发现不区分大小写,所以说,深刻的教训

认真读题!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

#include<bits/stdc++.h>
#include<unordered_map>
#define int int64_t
using namespace std;
int n, m,nxt[1000];
string s1, s2;
void getNext() {
    int pre = 0, i = 1;
    while (i < s1.size()) {
        if (s1[i] == s1[pre]) {
              pre++;
              nxt[i++] = pre;
         }
        else {
            if (pre) pre = nxt[pre - 1];
            else i++;
        }
    }
}
void solve() {
    int cnt = 0;
    cin >> n >> m >> s1 >> s2;
    for (int i = 0; i < n; ++i) s1[i] = tolower(s1[i]);
    for (int i = 0; i < m; ++i) s2[i] = tolower(s2[i]);
    memset(nxt, 0, sizeof nxt);
    getNext();
    int i = 0, j = 0;
    while (i < s2.size()) {
        if (s1[j] == s2[i])i++, j++;
        else {
            if (j) j = nxt[j - 1];
            else i++;
        }
        if (j == s1.size()) {
            cnt++;
            j = nxt[j - 1];
        }
    }
    cout << cnt << endl;
}
signed main() {
    ios::sync_with_stdio(false); cin.tie(0), cout.tie(0);
    int  t; cin >> t;
    while (t--) {
        solve();
    }
    return 0;
}
相关推荐
manba_2 分钟前
leetcode-560. 和为 K 的子数组
数据结构·算法·leetcode
liuyang-neu3 分钟前
力扣 11.盛最多水的容器
算法·leetcode·职场和发展
忍界英雄12 分钟前
LeetCode:2398. 预算内的最多机器人数目 双指针+单调队列,时间复杂度O(n)
算法·leetcode·机器人
Kenneth風车13 分钟前
【机器学习(五)】分类和回归任务-AdaBoost算法-Sentosa_DSML社区版
人工智能·算法·低代码·机器学习·数据分析
C7211BA30 分钟前
使用knn算法对iris数据集进行分类
算法·分类·数据挖掘
Tisfy33 分钟前
LeetCode 2398.预算内的最多机器人数目:滑动窗口+单调队列——思路清晰的一篇题解
算法·leetcode·机器人·题解·滑动窗口
程序猿练习生37 分钟前
C++速通LeetCode简单第18题-杨辉三角(全网唯一递归法)
c++·算法·leetcode
Huazzi.40 分钟前
算法题解:斐波那契数列(C语言)
c语言·开发语言·算法
汉字萌萌哒41 分钟前
【2022 CCF 非专业级别软件能力认证第一轮(CSP-J1)入门级 C++语言试题及解析】
数据结构·c++·算法
2301_8071805442 分钟前
icpc江西:L. campus(dij最短路)
算法