当前位置: 首页 > news >正文

数据结构(4.4)——求next数组

next数组的作用:当模式串的第j个字符失配时,从模式串的第next[j]的继续往后匹配

求模式串的next数组(手算)

next[1]

任何模式串都一样,第一个字符不匹配时,只能匹配下一个子串,因此,往后,next[1]都无脑写0

next[2] 

 任何模式串都一样,第二个字符不匹配时,只能匹配模式串的第1个字符,因此,往后,next[1]都无脑写1

next[3]  

在不匹配的位置前边,划一条分界线,模式串一步一步往后退,直到分界线之前"能对上",或模式串能完全跨过分界线为止,此时j指向哪儿,next数组值就是多少

 

next[4]  

在不匹配的位置前边,划一条分界线,模式串一步一步往后退,直到分界线之前"能对上",或模式串能完全跨过分界线为止,此时j指向哪儿,next数组值就是多少

next[5]

在不匹配的位置前边,划一条分界线,模式串一步一步往后退,直到分界线之前"能对上",或模式串能完全跨过分界线为止,此时j指向哪儿,next数组值就是多少

next[6]

在不匹配的位置前边,划一条分界线,模式串一步一步往后退,直到分界线之前"能对上",或模式串能完全跨过分界线为止,此时j指向哪儿,next数组值就是多少

 

总结

next[1]都无脑写0 

next[2]都无脑写1

其他next:在不匹配的位置前边,划一条分界线,模式串一步一步往后退,直到分界线之前"能对上",或模式串能完全跨过分界线为止,此时j指向哪儿,next数组值就是多少

例题:

求模式串:ababaa的next数组

//求next[1]

??????->??????//i=1->i=2

ababaa-> ababaa //j=0,第一个字符匹配失败,只能匹配下一个子串,++i,++j

next[1]=0;

//求next[2]

a?????->a??????  //i=2

ababaa->  ababaa  //j=1//第一个字符匹配成功,第二个字符匹配失败,i不动,j后退一步

next[2]=1;

//求next[3]

ab????->ab????//i=3

ababaa->    ababaa//第三个字符匹配失败,模式串后退两步,j指向1,j=1

next[3]=1

//求next[4]

aba???->aba???//i=4

ababaa->    ababaa//第四个字符匹配失败,模式串后退,第一个字符a和主串第三个字符a匹配,j指向2,j=2

next[4]=2

//求next[5]

abab??->abab??//i=5

ababaa->    ababaa//第五个字符匹配失败,模式串后退,字符串ab和主串第二个子串ab匹配,j指向3,j=3

next[5]=3

 

//求next[6]

ababa?->ababa?//i=6

ababaa->    ababaa//第六个字符匹配失败,模式串后退,字符串ab和主串第二个子串aba匹配,j指向4,j=4

next[6]=4

 例题2同理:

http://www.lryc.cn/news/400343.html

相关文章:

  • 《mysql篇》--JDBC编程
  • android studio 怎么下载 buildTool
  • copy 和 mutableCopy 有点乱
  • sqlalchemy通过查询参数生成query
  • 【JavaScript 算法】二分查找:快速定位目标元素
  • 论文研读:ViT-V-Net—用于无监督3D医学图像配准的Vision Transformer
  • C++入门到进阶(图文详解,持续更新中)
  • 【React Hooks原理 - useRef】
  • MVC之 IHttpModule管道模型《二》
  • 2025上海纺织助剂展会+上海织物整理剂展
  • 中科亿海微亮相慕尼黑上海电子展
  • Spring boot 2.0 升级到 3.3.1 的相关问题 (一)
  • 数据分析——Python网络爬虫(四){爬虫库的使用}
  • C++客户端Qt开发——信号和槽
  • 基于双向长短期记忆 BiLSTM 实现股票单变量时间序列预测(PyTorch版)
  • 微信小程序毕业设计-汽车维修项目管理系统项目开发实战(附源码+论文)
  • 学习大数据DAY16 PLSQL基础语法5
  • LabVIEW心电信号自动测试系统
  • 最值得推荐的10款Windows软件!
  • 游戏视频是后期配音好还是边录边配 游戏视频怎么剪辑制作才能火 视频剪辑免费软件
  • 配置 Node.js 内存限制
  • ORA-12518: TNS: 监听程序无法分发客户机连接
  • 2.5 计算机网络
  • 同三维T80004ESL编码器视频使用操作说明书:高清HDMI编码器,高清SDI编码器,4K超清HDMI编码器,双路4K超高清编码器
  • 「ETL趋势」分区支持PostgreSQL、Greenplum、Gauss200, 定时任务支持Kettle
  • vue 前端项目调用后端接口记录
  • 4.10、matlab生成脉冲序列:pulstran()函数
  • 【JAVA poi-tl-ext 富文本转word】
  • uniapp 小程序注册全局弹窗组件(无需引入,无需写标签)
  • python 语法学习 day 7