#include<iostream>

 using namespace std;

 #define MAX    255

 typedef unsigned char BYTE;

 typedef BYTE String[MAX+];

 bool strAssign(String& strTemp,char* Temp);   //定长字符串存储
bool strTravel(String& strTemp);          //打印
void KMP(String& strMother,String& strSon,int* pData);
void GetNext(String& strSon,int* pNext);
                                        //KMP算法的实现要求两个子函数 KMP() 和GetNext() void main()
{ String strMother;
memset(strMother,,sizeof(strMother)); String strSon;
memset(strSon,,sizeof(strSon)); strAssign(strMother,"HHHeHeHHe");
strAssign(strSon,"HeHe"); strTravel(strMother);
strTravel(strSon);
int* pData = (int*)malloc(sizeof(int)*(strMother[]+)); KMP(strMother,strSon,pData); int i = ;
for(i=;i<=pData[];i++)
{
cout<<pData[i]<<" "; }
cout<<endl; }
bool strAssign(String& strTemp,char* Temp)
{
strTemp[] = strlen(Temp); int i = ;
for(i=;i<=strTemp[];i++)
{
strTemp[i] = Temp[i-]; } return true; }
bool strTravel(String& strTemp)
{
int i = ;
for(i=;i<=strTemp[];i++)
{
cout<<strTemp[i]<<" "; } cout<<endl;
return true; }
void KMP(String& strMother,String& strSon,int* pData)
{
int* pNext = (int*)malloc(sizeof(int)*(strSon[]+)); GetNext(strSon,pNext); int i = ;
int j = ;
int k = ; while(i<=strMother[])
{
if(i==||strMother[i]==strSon[j])
{
i++;
j++; }
else
{
j = pNext[j]; } if(j>strSon[])
{
pData[k] = i-strSon[];
k++;
j=; } } pData[] = k-;
free(pNext); }
void GetNext(String& strSon,int* pNext)
{
pNext[] = ; int i = ;
int j = ; while(i!=strSon[])
{
if(j==||strSon[i]==strSon[j])
{
i++;
j++; pNext[i] = j; }
else
{
j = pNext[j]; } }
}

KMP字符串匹配的更多相关文章

  1. {Reship}{KMP字符串匹配}

    关于KMP字符串匹配的介绍和归纳,作者的思路非常清晰,推荐看一下 http://blog.csdn.net/v_july_v/article/details/7041827

  2. 洛谷P3375 - 【模板】KMP字符串匹配

    原题链接 Description 模板题啦~ Code //[模板]KMP字符串匹配 #include <cstdio> #include <cstring> int cons ...

  3. Luogu 3375 【模板】KMP字符串匹配(KMP算法)

    Luogu 3375 [模板]KMP字符串匹配(KMP算法) Description 如题,给出两个字符串s1和s2,其中s2为s1的子串,求出s2在s1中所有出现的位置. 为了减少骗分的情况,接下来 ...

  4. 洛谷P3375 [模板]KMP字符串匹配

    To 洛谷.3375 KMP字符串匹配 题目描述 如题,给出两个字符串s1和s2,其中s2为s1的子串,求出s2在s1中所有出现的位置. 为了减少骗分的情况,接下来还要输出子串的前缀数组next.如果 ...

  5. P3375 【模板】KMP字符串匹配

    P3375 [模板]KMP字符串匹配 https://www.luogu.org/problemnew/show/P3375 题目描述 如题,给出两个字符串s1和s2,其中s2为s1的子串,求出s2在 ...

  6. 洛谷—— P3375 【模板】KMP字符串匹配

    P3375 [模板]KMP字符串匹配 题目描述 如题,给出两个字符串s1和s2,其中s2为s1的子串,求出s2在s1中所有出现的位置. 为了减少骗分的情况,接下来还要输出子串的前缀数组next. (如 ...

  7. P3375 模板 KMP字符串匹配

    P3375 [模板]KMP字符串匹配 来一道模板题,直接上代码. #include <bits/stdc++.h> using namespace std; typedef long lo ...

  8. KMP字符串匹配 模板 洛谷 P3375

    KMP字符串匹配 模板 洛谷 P3375 题意 如题,给出两个字符串s1和s2,其中s2为s1的子串,求出s2在s1中所有出现的位置. 为了减少骗分的情况,接下来还要输出子串的前缀数组next.(如果 ...

  9. KMP字符串匹配学习

    KMP字符串匹配学习 牛逼啊 SYC大佬的博客

  10. KMP(字符串匹配)

    1.KMP是一种用来进行字符串匹配的算法,首先我们来看一下普通的匹配算法: 现在我们要在字符串ababcabcacbab中找abcac是不是存在,那么传统的查找方法就是一个个的匹配了,如图: 经过六趟 ...

随机推荐

  1. Qt之再谈窗体阴影

    前面就窗口阴影已经写过一篇博客,使用九宫格的思路实现的,在我看来,凡是用程序能实现的尽量不要使用图片代替(在保证效率的前提下),今天再次分享关于我的一些小见解!     先看效果:       窗口阴 ...

  2. springmvc 传递和接收数组参数

    java url中如何传递数组,springMVC框架controller类如何接收数组参数? 下面介绍一下URL中传递数组参数方法: dd.do?titles[]=col1&titles[] ...

  3. ASP.NET打印EXCEl报表技术总结

    序言:我们在做企业项目或者一些管理系统的时候往往会用到导出到excel报表这项功能,下面我介绍的是用windows自带的excel来打印 首先必须引入:Interop.Excel.dll.Intero ...

  4. [jQuery]无法获取隐藏元素(display:none)宽度(width)和高度(height)的新解决方案

    在做茶城网改版工作的时候,又遇到一个新问题,我需要用jQuery写一个通过点击左右图标来翻阅图片的小插件,写好后测试可以正常运行,但是放到Tab中后发现只有第一个Tab中的代码能够正常运行,其它全部罢 ...

  5. 图片占位 css

    手机端图片高度和宽度不能自动比例缩小的问题 <!DOCTYPE html> <html> <head> <meta charset="utf-8&q ...

  6. ORACLE 查询表定义

    很多文章使用DESC tablename查看,这是查看的表结构,不是表定义. 如下: 1.set long 99999;  --增大输出缓冲区 2.SELECT dbms_metadata.get_d ...

  7. python正则表达式练习篇

    练习一: 利用who命令输出所有已经登录系统的用户的信息,并把登录名.用户登录时的电传.登录时间.登录地址利用正则表达式分割开来. 数据的格式: %who wesc console Jun 20 20 ...

  8. c++对文件操作的支持(二)

    #include <stdio.h> #include <iostream> #include <fstream> using namespace std; voi ...

  9. Web应用的部署

    本文将介绍一些Web应用的部署: 部署规则 要成功地部署一个Web应用,必须遵循以下目录结构. 1.WEB-INF一定要直接放到应用上下文(Webapp)之下. 2.classes目录必须直接放在WE ...

  10. Maven管理Android项目1

    maven-android-plugin网站:https://code.google.com/p/maven-android-plugin/wiki/GettingStarted   android ...