ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

2022/7/27 自学记录

2022-07-27 20:33:10  阅读:154  来源: 互联网

标签:nxt 27 && ++ int while 2022 自学 size


发现自己 KMP 忘了,于是再学一遍。

懒得写了,直接写题。

P3375 【模板】KMP字符串匹配

挂一个模板

#include <bits/stdc++.h>

using namespace std;
using i64 = long long;

int main() {
    ios::sync_with_stdio(false);
    cin.tie(0);

    string a, b;
    cin >> a >> b;

    int n = a.size(), m = b.size();
    vector<int> nxt(m + 1, 0);
    for (int i = 1, j = 0; i < m; i++) {
        while (j && b[i] != b[j]) j = nxt[j];
        if (b[i] == b[j]) j++;
        nxt[i + 1] = j;
    }
    for (int i = 0, j = 0; i < n; i++) {
        while (j && a[i] != b[j]) j = nxt[j];
        if (a[i] == b[j]) j++;
        if (j == m) {
            cout << i - m + 2 << '\n';
        }
    }
    for (int i = 0; i < m; i++) {
        cout << nxt[i + 1] << " ";
    }

    return 0;
}

P2375 [NOI2014] 动物园

可以使用 DP 的思想解决这个问题。

令 \(f_i\) 表示第 \(i\) 位的前后缀个数,然后要求一个不重叠,于是在代码中加上这样一行就解决了

while ((j << 1) > (i + 1)) j = nxt[j];

求 \(f_i\) 显然了, 就是

\[f_i= \left\{ \begin{array}{lcl} 0 \ \ \ \ (i = 0) \\ 1 \ \ \ \ (i = 1) \\ f_{nxt_i} + 1\ \ \ \ \ (i \geq 2) \end{array} \right. \]

void solve() {
    string s;
    cin >> s;

    int n = s.size();
    vector<int> nxt(n + 1), f(n + 1);
    f[1] = 1;
    for (int i = 1, j = 0; i < n; i++) {
        while (j && s[i] != s[j]) j = nxt[j];
        if (s[i] == s[j]) j++;
        nxt[i + 1] = j;
        // f[i + 1] = f[j] + 1;
    }
    for (int i = 2; i < n; i++) {
        f[i] = f[nxt[i]] + 1;
    }
    Z sum = 1;
    for (int i = 1, j = 0; i < n; i++) {
        while (j && s[i] != s[j]) j = nxt[j];
        if (s[i] == s[j]) j++;
        while ((j << 1) > (i + 1)) j = nxt[j];
        sum *= (f[j] + 1);
    }
    cout << sum.val() << "\n";
}

标签:nxt,27,&&,++,int,while,2022,自学,size
来源: https://www.cnblogs.com/Zheng-XiangYu/p/16526108.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有