比较好的KMP博客
从头到尾彻底理解KMP
#include<map> #include<set> #include<cmath> #include<stack> #include<queue> #include<cstdio> #include<string> #include<vector> #include<cstring> #include<iostream> #include<algorithm> #include<functional> using namespace std; const int MX = 1e6 + 5; char S1[MX], S2[MX]; int Next[MX]; int KMP(char *A, char *B) { int m = strlen(A), n = strlen(B); Next[0] = 0; for(int i = 1; i < n; i++) { int k = Next[i - 1]; while(B[i] != B[k] && k) k = Next[k - 1]; Next[i] = B[i] == B[k] ? k + 1 : 0; } int ans = 0, j = 0; for(int i = 0; i < m; i++) { while(A[i] != B[j] && j) j = Next[j - 1]; if(A[i] == B[j]) j++; if(j == n) ans++; } return ans; } int main() { int T, ansk = 0; //freopen("input.txt", "r", stdin); scanf("%d", &T); while(T--) { scanf("%s%s", S1, S2); printf("%d\n", KMP(S2, S1)); } return 0; }
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步