当前位置:  编程技术>c/c++/嵌入式

c语言中使用BF-KMP算法实例

    来源: 互联网  发布时间:2014-10-22

    本文导语:  直接上代码 代码如下:#define _CRT_SECURE_NO_WARNINGS#include#include#include #define MAX_SIZE 255    //定义字符串的最大长度 typedef unsigned char SString[MAX_SIZE];//数组第一个保存长度//BFint BFMatch(char *s,char *p){    int i,j;    i=0;    while(i < strlen(...

直接上代码

代码如下:

#define _CRT_SECURE_NO_WARNINGS
#include
#include
#include

#define MAX_SIZE 255    //定义字符串的最大长度

typedef unsigned char SString[MAX_SIZE];//数组第一个保存长度
//BF
int BFMatch(char *s,char *p)
{
    int i,j;
    i=0;
    while(i < strlen(s))
    {
        j=0;
        while(s[i]==p[j]&&j < strlen(p))
        {
            i++;
            j++;
        }
        if(j==strlen(p))
            return i-strlen(p);
        i=i-j+1;                //指针i回溯
    }
    return -1;   
}
//getNetx
void getNext(char *p,int *next)
{
    int j,k;
    next[0]=-1;
    j=0;
    k=-1;
    while(j < strlen(p)-1)
    {
        if(k==-1||p[j]==p[k])    //匹配的情况下,p[j]==p[k]
        {
            j++;
            k++;
            next[j]=k;
        }
        else
        {                  //p[j]!=p[k]
            k=next[k];
        }
    }
}

//KMP
int KMPMatch(char *s,char *p)
{
    int next[100];
    int i,j;
    i=0;
    j=0;
    getNext(p,next);
    while(i < strlen(s))
    {
        if(j==-1||s[i]==p[j])
        {
            i++;
            j++;
        }
        else
        {
            j=next[j];       //消除了指针i的回溯
        }
        if(j==strlen(p))
        {
            return i-strlen(p);
        }
    }
    return -1;
}

int main()
{
    int a, b;
    char s[MAX_SIZE], p[MAX_SIZE];

    printf("请输入模式串:");
    scanf("%s", &s);
    printf("请输入子串:");
    scanf("%s", &p);

    a = BFMatch(s, p);
    b = KMPMatch(s, p);

    if(a != -1)
    {
        printf("使用BF算法:%dn", a);
    }
    else
    {
        printf("未匹配n");
    }

    if(b != -1)
    {
        printf("使用KMP算法:%dn", a);
    }
    else
    {
        printf("未匹配n");
    }

    system("pause");
}

结果

代码如下:

请输入模式串:lalalalalaaaa
请输入子串:lalaa
使用BF算法:6
使用KMP算法:6
请按任意键继续. . .

    
 
 

您可能感兴趣的文章:

  • c语言实现MD5算法完整代码示例
  • LM优化算法的C语言实现 levmar
  • MD5算法的C语言实现
  • c语言的金钱算法
  • c语言 汉诺塔算法代码
  • C语言快速幂取模算法小结
  • C语言实现的PNPoly算法代码例子
  • C语言 扩展欧几里得算法代码
  • c语言快速排序算法示例代码分享
  • C语言对堆排序一个算法思路和实现代码
  • c语言实现奇偶排序算法
  • C语言的数字游戏算法效率问题探讨实例
  • 纯C语言:贪心Prim算法生成树问题源码分享
  • C语言实现二叉树遍历的迭代算法
  • C语言kmp算法简单示例和实现原理探究
  • c语言实现单链表算法示例分享
  • 马尔可夫链算法(markov算法)的awk、C++、C语言实现代码
  • C语言位图算法详解
  • C语言实现魔方阵算法(幻方阵 奇魔方 单偶魔方实现)
  • C语言实现的排列组合问题的通用算法、解决方法
  • 最小生成树算法C语言代码实例
  • HTML超文本标记语言教程及实例
  • LINUX 或者Windows 如何保证一个进程只有一个实例在运行?如果是C语言,JAVA语言开发,又怎么样保证?
  • 大家帮我推荐些在linux下用c语言对数据库操作编程的实例或资料吧!谢谢!
  • C语言构建动态数组完整实例
  • C语言实现堆排序的简单实例
  • C语言实现杨辉三角实例
  • c语言 字符串转大写的简单实例
  • C语言二维数组的处理实例
  • c语言如何实现只运行单个进程实例?
  • C语言中自动隐式转换与类型强制转换实例分析
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 以NetBeans IDE为例介绍如何使用XML中Schema语言
  • javascript开源软件 iis7站长之家
  • 使用c语言判断100以内素数的示例(c语言求素数)
  • 在linux下使用C语言一般是使用什么编程工具呢???
  • 在AIX和UNIX上可以使用什么编程语言?
  • 如何获取客户端浏览器所使用的语言,特别是要区分简繁体!
  • 我想在linux下开发软件,但不知道使用什么语言好,和使用什么开发工具
  • 如何使用汇编语言
  • linux下用c语言写的程序,其中可以使用STL模板吗?先谢谢各位
  • c语言在unix系统下,如何获取cpu使用率
  • 如何在C语言的宏中使用类型关键字
  • 各位大侠,请推荐几本在UNIX环境下使用标准C语言编程的好书.谢谢啊!!!
  • 我是一个linux新手,不知道如何在linux进行C语言的编写和使用?
  • 如何使用yacc分析c语言程序?
  • 菜鸟问题——其他语言怎样使用Java编写的程序(明确地说,使Class)
  • 在语言中,什么是共享内存,怎样使用,举例?
  • 如何使用c语言获取当前系统的时间,就是那个秒数?
  • ****请问谁有linux下c 语言函数的使用说明呀??要中文的!!!****
  • 在linux下,C语言编程,使用tell函数的问题
  • C语言中宏定义使用的小细节
  • linux使用c语言怎样实现程序唯一性
  • 2013年7月和2013年8月编程语言排行榜
  • 如何在GTK2.0下实现国际化(语言选择根据自己设置的语言,不用系统的语言)
  • 2017 年热门编程语言排行榜出炉,你的语言上榜没?
  • C语言中有指针,因此C语言可以创建链表,那么Java语言没有指针,那Java是否可以创建链表呢?
  • 苹果OS X和IOS下最新编程语言swift介绍
  • 求助,在linux下,c语言和汇编语言的接口是什么?
  • c语言判断某一年是否为闰年的各种实现程序代码
  • C语言中间语言 CIL
  • PHP编程语言介绍及安装测试方法
  • 最近学JSP,苦于HTML语言和JAVA语言太差,请教推荐几本书,thanks.


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3