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;
}
相关推荐
空白到白5 小时前
决策树-面试题
算法·决策树·机器学习
flashlight_hi5 小时前
LeetCode 分类刷题:2563. 统计公平数对的数目
python·算法·leetcode
前端世界5 小时前
HarmonyOS 数据处理性能优化:算法 + 异步 + 分布式实战
算法·性能优化·harmonyos
楼田莉子5 小时前
C++算法专题学习:栈相关的算法
开发语言·c++·算法·leetcode
kyle~6 小时前
排序---冒泡排序(Bubble Sort)
c语言·c++·算法
l1t6 小时前
我改写的二分法XML转CSV文件程序速度追上了张泽鹏先生的
xml·c语言·人工智能·算法·expat
一碗白开水一6 小时前
【论文阅读】Far3D: Expanding the Horizon for Surround-view 3D Object Detection
论文阅读·人工智能·深度学习·算法·目标检测·计算机视觉·3d
轮到我狗叫了6 小时前
力扣.1054距离相等的条形码力扣767.重构字符串力扣47.全排列II力扣980.不同路径III力扣509.斐波那契数列(记忆化搜索)
java·算法·leetcode
久菜盒子工作室6 小时前
量化金融|基于算法和模型的预测研究综述
算法·金融
CoovallyAIHub7 小时前
SBP-YOLO:面向嵌入式悬架的轻量实时模型,实现减速带与坑洼高精度检测
深度学习·算法·计算机视觉