/**
* 看了 b站视频 BV1jb411V78H 对KMP有了一点理解,然后我写了这个代码
* 这个代码和视频里面的有一点不同,字符串是从 0 开始的,而不是从1 开始的
* 希望能够帮到学习KMP的人
*/ #include <stdbool.h>
#include <malloc.h>
#include "KMP.h" // KMP.h 内容
/*
#define MAXSIZE (255) typedef struct {
char ch[MAXSIZE + 1];
int length;
}SString; void Next(SString const *t);
extern int *next;
int IndexOf_KMP(SString const *s, SString const *t);
*/ int *next; // 计算 next数组 /**
* 计算 0-based 模式串t的next数组
* @param t 模式串
*/
void Next(SString const *t) {
// 模式串 0 开始
int length = t->length; // 分配 next数组 所需要的空间
next = (int *)malloc(sizeof(int) * length);
for (int *p = next; p < next + length; p++)
{
*p = 0;
} for (int i = 0; i < length; i++)
{
if (i <= 1) // 前两个next[i]置为-1
{
next[i] = -1;
continue;
} // 执行下面的语句的时候, 一定有 i >= 2 int maxlen = 0; // 存储最长公共前后缀的长度 /**
* // len 表示前缀或后缀的最大长度, 可取的值是 [1..i-1] // i 为(模式串或next数组)的访问下标
* 这里主要是 对 模式串在i位置 求 它的最大公共前后缀的长度
* 从 1 开始 到 i-1 一个一个去试
*
*/
for (int len = 1; len < i; len++)
{
int val = 0;
bool flag = false; for (int j = 0, k = i - len; j < len; j++, k++)
{
if (t->ch[j] == t->ch[k])
{
}
else
{
flag = true; // len 长度的公共前后缀匹配失败
break;
}
} if (flag == false) // 公共前后缀长度为len
val = len;
if (val > maxlen) // 这个比较不是必须的,因为找公共前后缀的长度的时候, len 从 1 到 i-1
maxlen = val; // maxlen 就是 next[i]的值了
}
next[i] = maxlen;
}
} // 调用这个函数之前,一定要调用 Next函数,为模式串构建 next数组
int IndexOf_KMP(SString const *s, SString const *t)
{
// 开始匹配 int i = 0, j = 0; // i 表示主串的下标, j 表示模式串的下标
while (i < s->length)
{
if (j == -1 || s->ch[i] == t->ch[j])
{
i++;
j++;
}
else
{
j = next[j];
} // 匹配成功
if (j == t->length)
{
return i - t->length;
}
} // 匹配失败
return -1;
}

模式串 从 0 开始的KMP算法的更多相关文章

  1. 串匹配模式中的BF算法和KMP算法

    考研的专业课以及找工作的笔试题,对于串匹配模式都会有一定的考察,写这篇博客的目的在于进行知识的回顾与复习,方便遇见类似的题目不会纠结太多. 传统的BF算法 传统算法讲的是串与串依次一对一的比较,举例设 ...

  2. 数据结构(十六)模式匹配算法--Brute Force算法和KMP算法

    一.模式匹配 串的查找定位操作(也称为串的模式匹配操作)指的是在当前串(主串)中寻找子串(模式串)的过程.若在主串中找到了一个和模式串相同的子串,则查找成功:若在主串中找不到与模式串相同的子串,则查找 ...

  3. 字符串与模式匹配算法(三):KMP算法

    一.KMP算法介绍 KMP算法与前面的MP算法一脉相承,都是充分利用先前匹配的过程中已经得到的结果来避免频繁回溯.回顾一下MP算法,如下图的模式串偏移,当前模式字符串P的左端的p0与目标字符串T中tj ...

  4. 字符串模式匹配之KMP算法的next数组详解与C++实现

    相信来看next数组如何求解的童鞋已经对KMP算法是怎么回事有了一定的了解,这里就不再赘述,附上一个链接吧:https://www.cnblogs.com/c-cloud/p/3224788.html ...

  5. (原创)白话KMP算法(续)

    第二章:KMP改良算法 第一章里面我们讲完了KMP算法的next数组实现法,回忆一下其实最重要的内容无非就是一.理解 i 指针无用回溯的意义,二.理解 j 指针的定位和模式串中每个元素重复度的关系,三 ...

  6. Java数据结构之字符串模式匹配算法---KMP算法2

    直接接上篇上代码: //KMP算法 public class KMP { // 获取next数组的方法,根据给定的字符串求 public static int[] getNext(String sub ...

  7. 串的匹配:朴素匹配&amp;KMP算法

    引言 字符串的模式匹配是一种经常使用的操作. 模式匹配(pattern matching),简单讲就是在文本(text,或者说母串str)中寻找一给定的模式(pattern).通常文本都非常大.而模式 ...

  8. KMP算法-Java实现

    目的: 为了解决字符串模式匹配 历程: 朴素模式匹配:逐次进行比较 KMP算法:利用匹配失败得到的信息,来最大限度的移动模式串,以此来减少比较次数提高性能 概念: m:是目标串长度 n:是模式串长度 ...

  9. 【模式匹配】KMP算法的来龙去脉

    1. 引言 字符串匹配是极为常见的一种模式匹配.简单地说,就是判断主串\(T\)中是否出现该模式串\(P\),即\(P\)为\(T\)的子串.特别地,定义主串为\(T[0 \dots n-1]\),模 ...

随机推荐

  1. 力扣Leetcode 198. 打家劫舍

    打家劫舍 你是一个专业的小偷,计划偷窃沿街的房屋.每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警. 给定 ...

  2. hdu 4010 Lct动态链接树

    #pragma comment(linker, "/STACK:1024000000,1024000000") #include <cstdio> #include & ...

  3. Linux 用户与权限

    这些天一直在看Linux的命令但是却没有写文章,因为感觉没有必要,哪些简单的命令,vi cat cd 啥的,是个做开发的就知道,所以就没写; 用户管理 第一个我们知道的用户就是Root 没错哦,这就是 ...

  4. C:将算术表达式的符号和数分开

    程序: #include <stdio.h> #include <string.h> static int pos=; static char* line; void test ...

  5. JVM调优和深入了解性能优化

    JVM调优的本质: 并不是显著的提高系统性能,不是说你调了,性能就能提升几倍或者上十倍,JVM调优,主要调的是稳定.如果你的系统出现了频繁的垃圾回收,这个时候系统是不稳定的,所以需要我们来进行JVM调 ...

  6. Windows安装tensorflow教程 GPU版

    PS:这是GPU版本,CPU版会用笔记本环境另写一篇博客. 前置准备 查看GPU型号 电脑桌面->右键我的电脑->选择管理->点击设备管理器  如下图: 如果不是英伟达显卡,那么不用 ...

  7. TP6.0 一对一模型关联 hasOne

    本文测试关联方法都采用预载入查询 $data = User::with('profile')->select(); halt($data->toArray()); 1. 创建数据表 -- ...

  8. TP6.0 获取请求对象的五种方式

    目录 1. 门面类 2. 依赖注入 3. 框架提供的基础控制器的 request 属性 4. request() 助手函数 5. app() 超级助手函数 think\Request.think\fa ...

  9. Priest John's Busiest Day(POJ 3683)

    原题如下: Priest John's Busiest Day Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 12162   ...

  10. 起redis服务时报错Creating Server TCP listening socket *:6379: bind: No such file or directory