C++ 数据结构之kmp算法中的求Next()函数的算法

发布时间 - 2026-01-11 02:02:33    点击率:

C++ 数据结构之kmp算法中的求Next()函数的算法

实例代码:


#include <iostream>
 
using namespace std;
 
void preKmp(char *c, int m, int Next[])
{
  int i=1,j=-1;
  Next[0]=-2;
  while(i<m)
  {
    if(j==-2)
     {
       Next[i]=-1;
       i++;
       j=-1;
     }
 
     ++j;
     if(i==m)
     return;
    if(c[i]==c[j])
     {
       Next[i]=j;
       ++i;
     }
    else if(j==0)
     {
       j=-2;
 
     }
    else j=Next[j-1];
  }
}
int main()
{
  cout << "Hello world!" << endl;
  char pat[12]="actabactace";
  int next[11];
  preKmp(pat,11,next);
  for(int i=0;i<11;i++)
    cout<<"next["<<i<<"]="<<next[i]<<endl;
  return 0;
}

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# kmp算法中的求Next()  # 数据结构kmp算法  # C++数据结构与算法之哈夫曼树的实现方法  # C++数据结构与算法之反转链表的方法详解  # C++数据结构与算法之双缓存队列实现方法详解  # C++ 数据结构之水洼的数量算法  # C++数据结构与算法之判断一个链表是否为回文结构的方法  # C++ 冒泡排序数据结构、算法及改进算法  # C++数据结构与算法的基础知识和经典算法汇总  # 数据结构  # 希望能  # 谢谢大家  # iostream  # lt  # include  # std  # namespace  # gt  # pre  # kmp  # strong  # cpp  # brush  # class  # pat  # endl  # world  # actabactace  # cout 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: js实现点击每个li节点,都弹出其文本值及修改  Laravel怎么使用Session存储数据_Laravel会话管理与自定义驱动配置【详解】  免费视频制作网站,更新又快又好的免费电影网站?  详解Oracle修改字段类型方法总结  HTML 中动态设置元素 name 属性的正确语法详解  Laravel如何实现API速率限制?(Rate Limiting教程)  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  网站页面设计需要考虑到这些问题  Laravel如何为API编写文档_Laravel API文档生成与维护方法  Laravel如何使用Gate和Policy进行授权?(权限控制)  如何用腾讯建站主机快速创建免费网站?  中山网站制作网页,中山新生登记系统登记流程?  js代码实现下拉菜单【推荐】  jimdo怎样用html5做选项卡_jimdo选项卡html5实现与切换效果【指南】  Laravel怎么实现观察者模式Observer_Laravel模型事件监听与解耦开发【指南】  Linux后台任务运行方法_nohup与&使用技巧【技巧】  Laravel怎么配置自定义表前缀_Laravel数据库迁移与Eloquent表名映射【步骤】  如何快速打造个性化非模板自助建站?  新三国志曹操传主线渭水交兵攻略  如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?  在线教育网站制作平台,山西立德教育官网?  怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?  Laravel安装步骤详细教程_Laravel环境搭建指南  C++用Dijkstra(迪杰斯特拉)算法求最短路径  如何用狗爹虚拟主机快速搭建网站?  Laravel Sail是什么_基于Docker的Laravel本地开发环境Sail入门  详解Nginx + Tomcat 反向代理 如何在高效的在一台服务器部署多个站点  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  湖南网站制作公司,湖南上善若水科技有限公司做什么的?  千问怎样用提示词获取健康建议_千问健康类提示词注意事项【指南】  Android自定义控件实现温度旋转按钮效果  打造顶配客厅影院,这份100寸电视推荐名单请查收  太平洋网站制作公司,网络用语太平洋是什么意思?  作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】  Laravel广播系统如何实现实时通信_Laravel Reverb与WebSockets实战教程  油猴 教程,油猴搜脚本为什么会网页无法显示?  Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载  微信公众帐号开发教程之图文消息全攻略  如何快速使用云服务器搭建个人网站?  Python正则表达式进阶教程_复杂匹配与分组替换解析  EditPlus 正则表达式 实战(3)  如何有效防御Web建站篡改攻击?  如何利用DOS批处理实现定时关机操作详解  Windows10电脑怎么查看硬盘通电时间_Win10使用工具检测磁盘健康  JavaScript数据类型有哪些_如何准确判断一个变量的类型  Win11应用商店下载慢怎么办 Win11更改DNS提速下载【修复】  html5audio标签播放结束怎么触发事件_onended回调方法【教程】  Laravel怎么返回JSON格式数据_Laravel API资源Response响应格式化【技巧】  MySQL查询结果复制到新表的方法(更新、插入)  Python图片处理进阶教程_Pillow滤镜与图像增强