#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. DecimalFormat类

    DecimalFormat类也是Format的一个子类,主要作用是格式化数字. 在格式化数字的时候比直接使用NumberFormat更加方便,因为可以直接指定按用户自定义的方式进行格式化操作,与Sim ...

  2. Android学习笔记——ListView

    该工程的功能是实现在一个activity中显示一个列表 以下代码是MainActivity.java中的代码 package com.example.listview; import java.uti ...

  3. 深刻认识一下session

    session是什么: session即会话,是一种持续性,双向的连接. session和cookie在本质上没什么区别,都是针对http协议的局限性提出的一种保持客户端和服务端会话状态的机制. se ...

  4. nginx使用ssl模块配置支持HTTPS访问

    默认情况下ssl模块并未被安装,如果要使用该模块则需要在编译nginx时指定–with-http_ssl_module参数. 需求: 做一个网站域名为 www.localhost.cn 要求通过htt ...

  5. target 事件属性

    定义和用法 target 事件属性可返回事件的目标节点(触发该事件的节点),如生成事件的元素.文档或窗口. 语法 event.target 实例 下面的例子可获得触发事件的元素: <html&g ...

  6. android自定义控件(1)-点击实现开关按钮切换

    自定义控件的步骤.用到的主要方法:   1.首先需要定义一个类,继承自View:对于继承View的类,会需要实现至少一个构造方法:实际上这里一共有三个构造方法: public View (Contex ...

  7. 要让div中的float不会自动显示到下一行来?

    使用 高度 + hidden: 要尝试 恰当的 高度, 设置合适的 div的 height: ... 要让 float的 "最直接的" "亲生的 " " ...

  8. localdomain的linux域

    both和and的区别? both强调(两者)都,用于肯定语气, and字面意思是"和,而且",是用于表示并列关系的句子,通常位于最后两个人或物之间,将将人物串联起来 如: thi ...

  9. 时间处理工具类DateUtils

    public class DateUtils {         public static final String                            SHORT_DATE    ...

  10. Update-Package : Unable to load the service index for source https://api.nuget.org/v3/index.json.

    由于更改了项目"属性"的"目标框架"(原来的框架是".NET Frameword4.5"改为了".NET Frameword4&q ...