#include <stdio.h>
#include <stdlib.h>
#include <string>
#include<string.h>
#define MAXSTRLEN 255 /* 可以在255以内定义最大串长 */
typedef char SString[MAXSTRLEN + ]; /* 0号单元存放串的长度 */
void get_next(SString T, int next[]);
void get_nextval(SString T, int nextval[]);
int Index(SString S, SString T, int pos) {
int i = pos; int j = ;
while (i <= S[] && j <= T[]) {
if (S[i] == T[j]) {++i; ++j;} //继续比较后继字符
else {i = i - j + ; j = ;} //指针后退重新开始匹配
}
if (j > T[]) return i - T[];
else return ;
} int Index_KMP_1(SString S, SString T, int pos) {
int i = pos; int j = ;
int *next = (int *)malloc((T[] + ) * sizeof(int));
get_next(T, next);
while (i <= S[] && j <= T[]) {
if (j == || S[i] == T[j]) {++i; ++j;} //继续比较后继字符
else j = next[j]; //模式串向右移动
}
free(next);
if (j > T[]) return i - T[]; //匹配成功
else return ;
} void get_next(SString T, int next[]) {
int i = , j = ; next[] = ;
while (i < T[]) {
if (j == || T[i] == T[j]) {++i; ++j; next[i] = j;}
else j = next[j];
}
} int Index_KMP_2(SString S, SString T, int pos) {
int i = pos; int j = ;
int *nextval = (int *)malloc((T[] + ) * sizeof(int));
get_nextval(T, nextval);
while (i <= S[] && j <= T[]) {
if (j == || S[i] == T[j]) {++i; ++j;} //继续比较后继字符
else j = nextval[j]; //模式串向右移动
}
free(nextval);
if (j > T[]) return i - T[]; //匹配成功
else return ;
} void get_nextval(SString T, int nextval[]) {
int i = ; nextval[] = ; int j = ;
while (i < T[]) {
if (j == || T[i] == T[j]) {
++i; ++j;
if (T[i] != T[j]) nextval[i] = j;
else nextval[i] = nextval[j];
}
else j = nextval[j];
}
}
/*
样例
s:ababcabcacbab
t:abcac */
int main(){
SString S, T;
scanf("%s",S+);
S[]=strlen(S+);
S[S[]+]='\0'; scanf("%s",T+);
T[]=strlen(T+);
T[T[]+]='\0';
printf("Index: %d\n", Index(S, T, ));//暴力模式匹配方法
printf("Index_KMP_1: %d\n", Index_KMP_1(S, T, ));//KMP算法
printf("Index_KMP_2: %d\n", Index_KMP_2(S, T, ));//KMP优化算法
}

模式串匹配,kmp的更多相关文章

  1. 模式串匹配KMP详解

    关于KMP模式串匹配网上蛮多的. 对于KMP有自己理解所以写下来希望能够对你们的学习有帮助. 之前暑假的时候学过,然后好长时间没用发现又忘了,现在再看看发现有了新的理解. ============== ...

  2. 模式串匹配之KMP算法

    模式串匹配之KMP算法 KMP算法 模式值计算(next[j]) (1) next[0]=-1,  第一个字符模式值为-1 (2) next[j]=-1, T中下标为j的字符与首字符相同,且j前面的1 ...

  3. 单模式串匹配----浅谈kmp算法

    模式串匹配,顾名思义,就是看一个串是否在另一个串中出现,出现了几次,在哪个位置出现: p.s.  模式串是前者,并且,我们称后一个 (也就是被匹配的串)为文本串: 在这篇博客的代码里,s1均为文本串, ...

  4. hdu 1686 Oulipo 【KMP】(计算模式串匹配的次数——与已匹配的字串可以有交集)

    题目链接:https://vjudge.net/contest/220679#problem/B 题目大意: 输入一个T,表示有T组测试数据: 每组测试数据包括一个字符串W,T,T长度大于W小于100 ...

  5. AC自动机——多模式串匹配的算法思想

    标准KMP算法用于单一模式串的匹配,即在母串中寻求一个模式串的匹配,但是现在又存在这样的一个问题,如果同时给出多个模式串,要求找到这一系列模式串在母串存在的匹配个数,我们应该如何处理呢? 基于KMP算 ...

  6. 字符串匹配KMP算法详解

    1. 引言 以前看过很多次KMP算法,一直觉得很有用,但都没有搞明白,一方面是网上很少有比较详细的通俗易懂的讲解,另一方面也怪自己没有沉下心来研究.最近在leetcode上又遇见字符串匹配的题目,以此 ...

  7. 【转载】多模式串匹配之AC自动机

    原文地址:https://www.cnblogs.com/codeape/p/3845375.html 目录 [隐藏] 一.概述 二.AC算法思想 三.字典树tire的构造 四.搜索路径的确定 附录: ...

  8. 字符串匹配-KMP

    节选自 https://www.cnblogs.com/zhangtianq/p/5839909.html 字符串匹配 KMP O(m+n) O原来的暴力算法 当不匹配的时候 尽管之前文本串和模式串已 ...

  9. HDU1686 计算模式串匹配的次数

    题目大意: 输入一个T,表示有T组测试数据: 每组测试数据包括一个字符串W,T,T长度大于W小于1000000,w长度小于10000,计算W匹配到T中成功的次数: 这题很明显要用KMP算法,不然很容易 ...

  10. 《数据结构》之串的模式匹配算法——KMP算法

    //串的模式匹配算法 //KMP算法,时间复杂度为O(n+m) #include <iostream> #include <string> #include <cstri ...

随机推荐

  1. codeforces 712B. Memory and Trident

    题目链接:http://codeforces.com/problemset/problem/712/B 题目大意: 给出一个字符串(由'U''D''L''R'),分别是向上.向下.向左.向右一个单位, ...

  2. C++ wMA 算法

    CMakeLists.txt project(aaa) add_library(aaa SHARED aaa.cpp) add_executable(bbb bbb.cpp) target_link_ ...

  3. Using Flash Builder with Flash Professional

    http://help.adobe.com/en_US/flashbuilder/using/WSc5cd04c102ae3e97-6e5d439512e1414e588-8000.html

  4. git 删除远程分支

    http://www.cnblogs.com/shiningrise/archive/2013/03/12/2956779.html 一不小心把本地的临时分支push到server上去了,想要删除.一 ...

  5. Yii2 rules验证规则

    Rules验证规则:  required : 必须值验证属性||CRequiredValidator 的别名, 确保了特性不为空. [['字段名1','字段名2'],required]    //字段 ...

  6. 修改ubuntu DNS的步骤/wget url报错: unable to resolve host address的解决方法

    wget url 报错:unable to resolve host address ‘url’,显然是无法解析主机地址,这就能看出是DNS解析的问题.解决办法就是配置可用的dns 一般是修改成为谷歌 ...

  7. Android Studio-设置鼠标悬停显示方法声明

  8. Java Programming Test Question 4

    What will be the boolean flag value to reach the finally block? public class JPTQuestion4 { public s ...

  9. git执行pull命令时,报错

    在图形界面中,执行拉取操作时,出现下面的错误. You asked to pull from the remote 'origin', but did not specifya branch. Bec ...

  10. oracle 中的Ipad()函数

    本文基于转载: lpad函数从左边对字符串使用指定的字符进行填充.lpad意思是从左边填充的意思. 语法格式如下: lpad( string, padded_length, [ pad_string ...