KMP匹配算法 C语言版本

【C语言】KMP匹配算法

这个就是用于找到子串在母串中出现的位置,然后相较于传统的比对,进行了回溯的优化,使算法运行效率更高。这个学过数据结构的同学应该知道,在此不过多阐述。
这个算法目前是只能计算出第一次出现的位置,我是用作解析Json数据的。一共就两个函数,一个是get_next数组的 就是回溯指标,具体的原理可以去看看书或者找视频。然后就是找到位置IndexOf,返回位置 0表示没有找到 1表示第一个位置对应数组的下标0 。

C语言代码

#include <stdio.h>

typedef unsigned char UINT8;
typedef signed char INT8;
typedef unsigned short UINT16;
typedef signed short INT16;
typedef unsigned int UINT32;
typedef signed int INT32;
typedef long long UINT64;

void get_next(UINT8 *data, UINT8 *next, UINT8 DataLen);
UINT8 IndexOf(UINT8 *Data, UINT8 *Buf,UINT8 DataLen,UINT8 BufLen);
/******************************************************************************
** Function    : Index_Start
** Description : 找出次数据出现的位置 本质就是比对数据 使用KMP算法
** Input       : UINT8 *Data,源数据 UINT8 *Buf目标数据
** Output      : UINT8 返回的是第几个位置出现第一次
*******************************************************************************/
UINT8 IndexOf(UINT8 *Data, UINT8 *Buf,UINT8 DataLen,UINT8 BufLen)
{
    UINT8 i=0, j=0;
    UINT8 next[255];

    get_next(Buf,next,BufLen);
    while ((i<DataLen)&&(j<BufLen))
    {
        if((j==0)||(Data[i]==Buf[j]))
        {
            i++; 
            j++;
        }
        else
        j=next[j];
    }

    if(j>=BufLen)
        return i-BufLen;
    else
        return 0;
}

/******************************************************************************
** Function    : get_next
** Description : 计算KMP要使用的next数组
** Input       : UINT8 *data 对比数据, int *next 带出去的next数据, UINT8 DataLen 比对数据的长度
** Output      : None
*******************************************************************************/
void get_next(UINT8 *data, UINT8 *next, UINT8 DataLen)
{
    int i, j;
    i = 1;
    j = 0;
    next[1] = 0;
    while (i < DataLen - 1)
    {
        if (j == 0 || data[i] == data[j]) // data[i]表示后缀的单个字符,data[j]表示前缀的单个字符
        {
            i++;
            j++;
            next[i] = j;
        }
        else
            j = next[j]; //若字符不相同,则j值回溯
    }
}


int main(int argc, char const *argv[])
{
    UINT8 data[]="#goodgoogle";
    UINT8 Buf[]="#google";
    printf("index=%d\n",IndexOf(data,Buf,sizeof(data),sizeof(Buf)));
    return 0;
}


结果是

index=4

第一次写文章有借鉴其他人的,感谢链接: link

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值