/**
* 看了 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. 企业网站SEO如何选择关键词

    http://www.wocaoseo.com/thread-17-1-1.html       企业网站的关键词应该如何去选择?有很多的企业老板在网上某某企业在网上做了一个网站,一天盈利多少后,觉得 ...

  2. SICP之1.3中文翻译题目错误

    原版题目: Exercise 1.3: Define a procedure that takes three numbers as arguments and returns the sum of ...

  3. 【Nginx】如何基于主从模式搭建Nginx+Keepalived双机热备环境?这是最全的一篇了!!

    写在前面 最近出版了<海量数据处理与大数据技术实战>,详情可以关注 冰河技术 微信公众号,查看<我的<海量数据处理与大数据技术实战>出版啦!>一文. 也有不少小伙伴 ...

  4. Unity游戏Mono内存管理及泄漏

    UWA工具 https://yq.aliyun.com/articles/435553 Unity游戏Mono内存管理及泄漏 https://wetest.qq.com/lab/view/135.ht ...

  5. 如何自制WC3地形纹理贴图

    http://world-editor-tutorials.thehelper.net/tilesets.php https://wenku.baidu.com/view/e761c953cc1755 ...

  6. 转载:SQL语句执行顺序

    转载地址:https://database.51cto.com/art/202001/609727.htm

  7. 转载 深入理解Nginx及使用Nginx实现负载均衡

    转载:https://developer.51cto.com/art/202001/609322.htm 正向代理是代理客户端,也就是客户端能真正接触到的,比如访问外网时需要使用VPN软件,在这个软件 ...

  8. selenium+python对表格数据的操作

    一.直接获取整个表格数据,包含表头 def table_info(self): tr_data=[] table_data=[] css='id=>useradmin'#根据表格id找到表格 s ...

  9. 【原创】Linux虚拟化KVM-Qemu分析(三)之KVM源码(1)

    背景 Read the fucking source code! --By 鲁迅 A picture is worth a thousand words. --By 高尔基 说明: KVM版本:5.9 ...

  10. docker push出现denied: requested access to the resource is denied

    今天想再 把本地的docker image 镜像push 到: https://hub.docker.com/ Step1: login : https://hub.docker.com/ [root ...