贴上C代码作参考,关于算法,可以参考网上的博文,但不要参考太多,一两篇相近的即可。

#include <stdio.h>
#include <stdlib.h>
#include <string.h> /* 获取pattern的next数组 */
void get_next(char * pattern, int * next, int len)
{
int i, index;
for (next[]=-, i=; i<len; i++)
{
if (pattern[i] == pattern[next[i-]+])
{
next[i] = next[i-] + ;
continue;
}
for (index=next[i-], next[i]=-; index!=-; index = next[index])
{
if (pattern[index+] == pattern[i])
{
next[i] = index + ;
break;
}
}
}
} int KMP(char * text, int tlen, char * pattern, int plen, int * ptr)
{
int i=, tindex=, pindex=, count=, * next = malloc(sizeof(int) * plen);
get_next(pattern, next, plen);
while (i < tlen)
{
if (pattern[pindex] == text[i])
{
i ++;
pindex ++;
if (pindex == plen)
{
pindex = ;
ptr[tindex++] = i-plen;
}
continue;
}
if (pindex == )
{
i ++;
}
else
{
pindex = next[pindex-] + ;
}
}
free(next);
return tindex;
} /* 按字符读入文件 */
int readText(const char * path, char * buf)
{
FILE * f;
int size;
f = fopen(path, "r");
if (!f)
{
return -;
}
fseek(f, , SEEK_END);
size = ftell(f);
rewind(f);
size = fread(buf, , size, f);
if (size <= )
{
size = -;
}
fclose(f);
return size;
} int main()
{
char text[] = {}, pattern[] = "aba";//"abcabdecabcabcd";
int * ptr, count = , plen, size = readText("file/text.txt", text), i=, j; if (size <= )
{
return -;
}
plen = strlen(pattern);
ptr = malloc((size/plen)*sizeof(int));
count = KMP(text, size, pattern, plen, ptr);
printf("%d results.\n", count);
while (i++ < count)
{
printf("index[%d] : ", i);
for (j=; j<plen; j++)
printf("%c",text[ptr[i-]+j]);
printf("\n======================\n");
}
free(ptr);
return ;
}

KMP算法C代码的更多相关文章

  1. KMP算法的代码实现

    上周算法班的BEN老师花了1个小时讲自动机和KMP的关系,结果failed...明天又要上课了,花了半天时间看了下KMP,暂且停留在利用next求模式中的跳跃长度,自动机那个还不能理解... 具体的可 ...

  2. 字符串匹配(KMP 算法 含代码)

    主要是针对字符串的匹配算法进行解说 有关字符串的基本知识 传统的串匹配法 模式匹配的一种改进算法KMP算法 网上一比較易懂的解说 小样例 1计算next 2计算nextval 代码 有关字符串的基本知 ...

  3. KMP算法【代码】

    废话不多说,看毛片算法的核心在于next数组. 很多地方用的都是严书上的方法来求解next数组,代码确实简洁明了,但是可能对于初学者来说不容易想到,甚至不是一下子能理解.(好了,其实我说的就是自己,别 ...

  4. KMP算法具体解释(转)

    作者:July. 出处:http://blog.csdn.net/v_JULY_v/. 引记 此前一天,一位MS的朋友邀我一起去与他讨论高速排序,红黑树,字典树,B树.后缀树,包含KMP算法,只有在解 ...

  5. 字符串匹配算法——KMP算法学习

    KMP算法是用来解决字符串的匹配问题的,即在字符串S中寻找字符串P.形式定义:假设存在长度为n的字符数组S[0...n-1],长度为m的字符数组P[0...m-1],是否存在i,使得SiSi+1... ...

  6. 字符串模式匹配KMP算法

    一篇不错的博客:http://www.cnblogs.com/dolphin0520/archive/2011/08/24/2151846.html KMP字符串模式匹配通俗点说就是一种在一个字符串中 ...

  7. KMP算法解析

    介绍一种高效的KMP算法:代码可以直接运行 #include <iostream> #include <iomanip> using namespace std; void p ...

  8. KMP算法具体解释

    这几天学习kmp算法,解决字符串的匹配问题.開始的时候都是用到BF算法,(BF(Brute Force)算法是普通的模式匹配算法,BF算法的思想就是将目标串S的第一个字符与模式串T的第一个字符进行匹配 ...

  9. 【字符串算法3】浅谈KMP算法

    [字符串算法1] 字符串Hash(优雅的暴力) [字符串算法2]Manacher算法 [字符串算法3]KMP算法 这里将讲述  [字符串算法3]KMP算法 Part1 理解KMP的精髓和思想 其实KM ...

随机推荐

  1. centos7之Python3.74安装

    安装版本:Python3.74 系统版本:centos7 系统默认安装Python2.7,保留. 安装/usr/bin/Python3 安装需要root权限. 安装Python3的准备工作: 1.安装 ...

  2. alpine 镜像 java 日志中文问号乱码

    0x00 前言 吾使用 alpine 作为基础镜像构建了 jdk8 镜像,为线上业务的 java 微服务架构提供支持,但是有容器运行的 java 服务中打印的日志中一旦出现中文,就会出现诸如以下的 ? ...

  3. Javascript实现简单地发布订阅模式

    不论是在程序世界里还是现实生活中,发布—订阅模式的应用都非常广泛.我们先看一下现实中的例子. 小明最近看上了一套房子,到了售楼处之后才被告知,该楼盘的房子早已售罄.好在售楼MM告诉小明,不久后还有一些 ...

  4. 解决 Nginx 代理Apex慢的问题

    前不久用 Nginx 代理 Oracle 的 Apex 速度非常慢,我之前Nginx 配置如下: server{ listen 80; server_name localhost; client_ma ...

  5. 本地在不安装Oracle的情况下安装PLSQL客户端

    本文解决问题:   通常在本地安装PLSQL后,如果本地没有安装Oracle数据库的话,PLSQL是不能使用的,输入远程数据库登录信息会提示:"Oracle Client没有正确安装&quo ...

  6. Springboot源码分析之项目结构

    Springboot源码分析之项目结构 摘要: 无论是从IDEA还是其他的SDS开发工具亦或是https://start.spring.io/ 进行解压,我们都会得到同样的一个pom.xml文件 4. ...

  7. 基于随机游走的三维网格分割算法(Random Walks)

    首先以一维随机游走(1D Random Walks)为例来介绍下随机游走(Random Walks)算法,如下图所示,从某点出发,随机向左右移动,向左和向右的概率相同,都为1/2,并且到达0点或N点则 ...

  8. Java连载22-for循环

    一.循环结构 在程序当中总有一些需要反复的/重复的执行的代码,假设没有循环结构,那么这段需要重复执行的代码自然式子最需要重复编写的,代码无法得到重复使用,所以多数编程语言都是支持循环结构的,将来把需要 ...

  9. CentOS -- RocketMQ HA & Monitoring

    RocketMQ Architecture NameServer Cluster Name Servers provide lightweight service discovery and rout ...

  10. svn checkout 单个文件

    $ svn co --depth=empty file:///usr/local/svn/calc calc_new $ cd calc_new $ svn up readme.txt 其中,calc ...