LOJ #103. 子串查找 (Hash)】的更多相关文章

题意 给定两个字符串 \(A\) 和 \(B\),求 \(B\) 在 \(A\) 中的出现次数. 思路 这是一道 \(KMP\) 的模板题. 不过 \(Hash\) 是个好东西,可以用 \(Hash\) 代替 \(KMP\) 算法. 预处理两个字符串的哈希值,然后将 \(A\) 中所有长度为 \(len(B)\) 的子串的哈希值与 \(B\) 的哈希值比较即可. 时间复杂度 \(O(n + m)\),与 \(KMP\) 算法一样! 缺点就是常数略大,而且不能用 \(KMP\) 的 \(next\…
题意 给出两个字符串 $s_1,s_2$,求 $s_2$ 在 $s_1$ 中出现的次数. 分析 预处理出两个字符串的哈希值,再逐位比较. 时间复杂度为 $O(n+m)$,和 $kmp$ 算法一样. 可能常数大一点点,还有就是没法用 $kmp$ 的 $next$ 数组. #include <bits/stdc++.h> using namespace std; typedef unsigned long long ull; ; ; ull h[maxn], p[maxn], ha; char s…
#include<stdio.h> #include<string.h> main() { char a[100],b[100]; int n,k,i; gets(a); gets(b); n=0; for(k=0;k<=strlen(a)-strlen(b);k++) { for(i=0;b[i]!=0;i++) if(b[i]!=a[k+i]) break; if(b[i]==0) n=n+1; } printf("%d\n",n); }/*A Not…
题目描述 这是一道模板题. 给定一个字符串 A AA 和一个字符串 B BB,求 B BB 在 A AA 中的出现次数. A AA 中不同位置出现的 B BB 可重叠. 输入格式 输入共两行,分别是字符串 A AA 和字符串 B BB. 输出格式 输出一个整数,表示 B BB 在 A AA 中的出现次数. 样例 样例输入 zyzyzyz zyz 样例输出 3 数据范围与提示 1≤A,B 1 \leq A, B1≤A,B 的长度 ≤106 \leq 10 ^ 6≤10​6​​,A AA.B BB …
题目描述 这是一道模板题. 给定一个字符串 A A A 和一个字符串 B B B,求 B B B 在 A A A 中的出现次数.AAA 和 BBB 中的字符均为英语大写字母或小写字母. A A A 中不同位置出现的 B B B 可重叠. 输入格式 输入共两行,分别是字符串 A A A 和字符串 B B B. 输出格式 输出一个整数,表示 B B B 在 A A A 中的出现次数. 样例 样例输入 zyzyzyz zyz 样例输出 3 数据范围与提示 1≤A,B 1 \leq A, B1≤A,B…
KMP算法学习链接:https://blog.csdn.net/starstar1992/article/details/54913261/ KMP算法:可以实现复杂度为O(m+n) 为何简化了时间复杂度: 充分利用了目标字符串ptr的性质(比如里面部分字符串的重复性,即使不存在重复字段,在比较时,实现最大的移动量). 上面理不理解无所谓,我说的其实也没有深刻剖析里面的内部原因. 考察目标字符串ptr: ababaca 这里我们要计算一个长度为m的转移函数next. next数组的含义就是一个固…
问题: 右移的位数和目标串没有多大的关系,和子串有关系. 已匹配的字符数现在已经有了,部分匹配值还没有. 前六位匹配成功就去查找PMT中的第六位. 现在的任务就是求得部分匹配表. 问题:怎么得到部分匹配表呢? 前缀集合和后缀集合取最长的交集就是部分匹配值. 例如,上图中前缀和后缀没有交集,部分匹配值就是0. 问题: 怎么编程产生部分匹配表呢? 从第2个字符开始递推,做一个贪心的假设,我们现在要求的匹配值是由上一次得到的匹配值加1得到. 假设有5个字符,当前的匹配值是3,当有6个字符时,我们就假设…
串的定长顺序存储#define MAXSTRLEN 255,//超出这个长度则超出部分被舍去,称为截断 串的模式匹配: 串的定义:0个或多个字符组成的有限序列S = 'a1a2a3…….an ' n = 0时为空串串的顺序存储结构:字符数组,串的长度就是数组末尾‘\0'前面的字符个数数组需在定义时确定长度,有局限性数组的最大长度二:串的堆分配存储表示typedef struct { char *ch; //若是非空串,则按串长分配存储区 //否则ch为空 int length; //串长度}HS…
1. 朴素算法的改进 (1)朴素算法的优化线索 ①因为 Pa != Pb 且Pb==Sb:所以Pa != Sb:因此在Sd处失配时,子串P右移1位比较没有意义,因为前面的比较己经知道了Pa != Sb,可以利用己经比较过的事实,而不必进行第2轮的比较,从而提高效率. ②KMP算法就是为解决这一问题而提出的! (2)部分匹配与前后缀(以S字符串“ABCDAB”为例) ①前缀:除了最后一个字符以外,一个字符的全部头部组合的集合.如,字符串S的前缀有{A,AB,ABC,ABCD,ABCDA},其中AB…
0.目录 1.KMP 子串查找算法 2.KMP 算法的应用 3.小结 1.KMP 子串查找算法 问题: 如何在目标字符串S中,查找是否存在子串P? 朴素解法: 朴素解法的一个优化线索: 示例: 伟大的发现: 匹配失败时的右移位数与子串本身相关,与目标串无关 移动位数 = 已匹配的字符数 - 对应的部分匹配值 任意子串都存在一个唯一的部分匹配表 部分匹配表示例: 问题: 部分匹配表是怎么得到的? 前缀 除了最后一个字符以外,一个字符串的全部头部组合 后缀 除了第一个字符以外,一个字符串的全部尾部组…