kmp算法的c语言,KMP算法 纯C实现

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

我自己写的KMP算法:

int nt[256];

void get_next1(char* T, int next[], int tlen)

{

int i = 0;

int j = 1;

next[0] = -1;

while( j 

{

if ( T[i] == T[j]  )

{

next[j] = 0;

i++;

}

else

{

next[j] = i;

i = 0;

}

j++;

}

}

int Index_KMP1(char* S, char* T,int slen, int tlen)

{

int i=0, j=0;

while( j 

{

if( j==-1 || S[i] == T[j] )

{

i++; j++;

}

else

{

j = nt1[j];

}

}

if( j == tlen )

{

return i-j;

}

else

{

return -1;

}

}

int main(int argc, char* argv[])

{

char ch[] = "aaaaa";

int len = (int)strlen(ch);

get_next1(ch, nt1, len);

for(int i=0; i

{

printf("%d[%c]=%d\n", i, ch[i], nt1[i]);

}

char sch[] = "abaavaaaaaab";

//char sch[] = "aawsdvddfabcdabceabcdfdwdasd";

int slen = (int)strlen(sch);

int ret = Index_KMP1(sch, ch, slen, len);

if(ret != -1)

{

char* tmp = sch + ret;

printf("%d, %s\n", ret, tmp);

}

else

printf("not find\n");

return 0;

}

我发现在数据结构的书中,用的SString类型,它的第一位是该字符的长度,所以和我们平时所需要的KMP算法不太兼容。

有什么问题,可以发到我的邮箱:bobyuworker@126.com

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/272620.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MyBatis多条件查询

1.MyBatis多条件查询1.1&#xff1a;使用实体类 将参数封装成对象接口&#xff1a;public List<User> getUserListByUser(User user);Mapper映射文件&#xff1a;<select id"getUserListByUser" resultType"User" parameterType"User"…

android 定位 广播,android - 如何触发广播接收器在GPS开启/关闭? - SO中文参考 - www.soinside.com...

如何触发广播接收器在GPS开启/关闭&#xff1f;问题描述 投票&#xff1a;35回答&#xff1a;5public class BootReceiver extends BroadcastReceiver {Overridepublic void onReceive(Context context, Intent intent) {if (intent.getAction().matches("android.locatio…

sphinx数据文件简析

Sphinx使用的文件包括 “sph”&#xff0c; “spa”&#xff0c; “spi”&#xff0c; “spd”, “spp”&#xff0c; “spm” &#xff0c;还有锁文件&#xff08;.spl&#xff09;。其中sph是系统的配置文件。其它则为索引文件。 l Spi 文件&#xff1a;保存WordId及指向此Wo…

收集一些常用的正则表达式

1 . 校验密码强度密码的强度必须是包含大小写字母和数字的组合&#xff0c;不能使用特殊字符&#xff0c;长度在8-10之间。^(?.*\\d)(?.*[a-z])(?.*[A-Z]).{8,10}$2. 校验中文字符串仅能是中文。^[\\u4e00-\\u9fa5]{0,}$3. 由数字、26个英文字母或下划线组成的字符串^\\w$4.…

C#实现图片的无损压缩

/// <summary>/// 图像缩略图处理/// </summary>/// <param name"bytes">图像源数据</param>/// <param name"compression">压缩质量 1-100</param>/// <param name"thumbWidth">缩略图的宽</para…

部署和调优 1.3 pureftp部署和优化-1

FTP 是 File Transfe Protocol&#xff08;文件传输协议&#xff09;的英文简称&#xff0c;而中文简称为 “文传协议” 用于 Internet 上的控制件的双向传输。 可以访问 www.pureftpd.org 官网 切换到下载目录 cd /usr/local/src 下载 wget http://download.pureftpd.org/…

android通知图标变白色,android 7.0通知图标出现白色方块

我使用下面的代码片段在我的Android应用程序中生成通知.private void sendNotification(String contentText, String message) {Intent resultIntent new Intent(this, MainActivity.class);resultIntent.putExtra("clear","clear");resultIntent.setFlag…

sqlserver 查找某个字段在哪张表里

如何查找某个字段属于哪张表&#xff1f;select [name] from [库名].[dbo].sysobjects where id in(select id from [库名].[dbo].syscolumns Where name字段名)

性能

成员嵌套越深&#xff0c;访问速度越慢。location.href 总是快于window.location.href&#xff0c;而后者也要比window.location.href.toString()更快。如果这些属性不是对象的实例属性&#xff0c;那么成员解析还要在每个点上搜索原形链&#xff0c;这将需要更长时间。 functi…

身份证号码有效性检测算法 ( js版 转 C#版 )

C#版#region 检测是否是正确的身份证/// <summary>/// 身份证验证/// </summary>/// <param name"num"></param>/// <returns></returns>public static bool isIdCardNo(string cardid){string num cardid.ToUpper();int[] fac…

android蓝牙移植,平板蓝牙测试与移植一

一&#xff0e;平板蓝牙测试硬件连接&#xff1a;进入系统的”设置”&#xff0c;开启“蓝牙”&#xff1a;可以看到扫描到其他的蓝牙设备&#xff0c;“Bluez”是平板的名称。点击“Bluez”&#xff0c;设置如下&#xff1a;点击要配对的蓝牙设备(手机等)&#xff0c;进行蓝牙…

ASP.NET系列:自定义配置节点的复用

appSettings太简单&#xff0c;为每个程序自定义配置节点太复杂&#xff0c;因此要解决app.config&web.config自定义配置的复用问题。 1.读取不依赖SectionName,根节点可以定义为任何名称。 2.足够简单&#xff0c;配置项采用name value的形式&#xff1b;足够复杂&#xf…

Web的26项基本概念和技术

Web开发是比较费神的&#xff0c;需要掌握很多很多的东西&#xff0c;特别是从事前端开发的朋友&#xff0c;需要通十行才行。今天&#xff0c;本文向初学者介绍一些Web开发中的基本概念和用到的技术&#xff0c;从A到Z总共26项&#xff0c;每项对应一个概念或者技术。Internet…

android 引入 .so,android studio引入so库方法(示例代码)

在Android Studio中引入so库&#xff0c;只需在app/jniLibs下放入so文件&#xff0c;然后在Module的build.gradle中加入&#xff1a;sourceSets {main {jniLibs.srcDirs [‘libs‘]}}完整的build.gradle如下&#xff1a;apply plugin: ‘com.android.library‘android {compil…

BZOJ3670: [Noi2014]动物园

Description 近日&#xff0c;园长发现动物园中好吃懒做的动物越来越多了。例如企鹅&#xff0c;只会卖萌向游客要吃的。为了整治动物园的不良风气&#xff0c;让动物们凭自己的真才实学向游客要吃的&#xff0c;园长决定开设算法班&#xff0c;让动物们学习算法。 某天&#x…

NSPredicate的用法、数组去重、比较...

一般来说这种情况还是蛮多的&#xff0c;比如你从文件中读入了一个array1&#xff0c;然后想把程序中的一个array2中符合array1中内容的元素过滤出来。 1&#xff09;例子一&#xff0c;一个循环 NSArray *arrayFilter [NSArray arrayWithObjects:"pict", "bla…

android one指纹解锁,小米用屏幕内指纹扫描仪准备了两部Android One手机

2017年9月发布时&#xff0c;小米米A1几乎成功一夜成名。小西米去年夏天推出了Mi A2和Mi A2 Lite。现在&#xff0c;正如XDA开发者所揭示的那样&#xff0c;中国品牌正在筹备第三代产品阵容。代号为“bamboo_sprout”和“cosmos_sprout” - 所有Android One智能手机都包含代号为…

hive日志位置(日志定位报错:Failed with exception Unable to move sourcehdfs://namenode/tmp/hive-pmp_bi/h)...

Hive中的日志分为两种 1. 系统日志&#xff0c;记录了hive的运行情况&#xff0c;错误状况。 2. Job 日志&#xff0c;记录了Hive 中job的执行的历史过程。日志查看方法 1&#xff0c;在本地运行机器上 hive日志存储位置在本机上&#xff0c;不是hadoop上&#xff1a;在hive/co…

控制算法用c语言实现的,PID控制算法的C语言实现(完整版)

【实例简介】该文件里面还有各种改进的PID的算法&#xff0c;比如变积分控制等【实例截图】【核心代码】具体 PID 实现代码如下&#xff1a;pid.Kp0.4;pid.Ki0.2;//增加了积分系数pid.Kd0.2;float PID_realize(float speed){float index;pid.SetSpeedspeed;pid.errpid.SetSpeed…

《挑战程序设计竞赛》2.2 贪心法-其它 POJ3617 3069 3253 2393 1017 3040 1862 3262

POJ3617 Best Cow Line 题意 给定长度为N的字符串S&#xff0c;要构造一个长度为N的字符串T。起初&#xff0c;T是一个空串&#xff0c;随后反复进行下列任意操作&#xff1a; 从S的头部&#xff08;或尾部&#xff09;删除一个字符&#xff0c;加到T的尾部 目标是构造字典序…