next数组计算.
来源:互联网 发布:mac系统怎么看文件大小 编辑:程序博客网 时间:2024/06/05 19:49
原文地址:http://blog.csdn.net/quitepig/article/details/7933977
首先看看next数组值的求解方法例如: 模式串 a b a a b c a c next值 0 1 1 2 2 3 1 2 next数组的求解方法是:第一位的next值为0,第二位的next值为1,后面求解每一位的next值时,根据前一位进行比较。首先将前一位与其next值对应的内容进行比较,如果相等,则该位的next值就是前一位的next值加上1;如果不等,向前继续寻找next值对应的内容来与前一位进行比较,直到找到某个位上内容的next值对应的内容与前一位相等为止,则这个位对应的值加上1即为需求的next值;如果找到第一位都没有找到与前一位相等的内容,那么需求的位上的next值即为1。 看起来很令人费解,利用上面的例子具体运算一遍。 1.前两位必定为0和1。 2.计算第三位的时候,看第二位b的next值,为1,则把b和1对应的a进行比较,不同,则第三位a的next的值为1,因为一直比到最前一位,都没有发生比较相同的现象。 3.计算第四位的时候,看第三位a的next值,为1,则把a和1对应的a进行比较,相同,则第四位a的next的值为第三位a的next值加上1。为2。因为是在第三位实现了其next值对应的值与第三位的值相同。 4.计算第五位的时候,看第四位a的next值,为2,则把a和2对应的b进行比较,不同,则再将b对应的next值1对应的a与第四位的a进行比较,相同,则第五位的next值为第二位b的next值加上1,为2。因为是在第二位实现了其next值对应的值与第四位的值相同。 5.计算第六位的时候,看第五位b的next值,为2,则把b和2对应的b进行比较,相同,则第六位c的next值为第五位b的next值加上1,为3,因为是在第五位实现了其next值对应的值与第五位相同。 6.计算第七位的时候,看第六位c的next值,为3,则把c和3对应的a进行比较,不同,则再把第3位a的next值1对应的a与第六位c比较,仍然不同,则第七位的next值为1。 7.计算第八位的时候,看第七位a的next值,为1,则把a和1对应的a进行比较,相同,则第八位c的next值为第七位a的next值加上1,为2,因为是在第七位和实现了其next值对应的值与第七位相同。
nextval数组的求解方法是:nextval[1]=0。从第二位开始,若要求nextval[i],将next[i]的值对应的位的值与i的值进行比较(例如,第i为的值为'b',next[i]=3,则将i的值'b'与第三位的值进行比较),若相等,nextval[i]=nextval【next[i]】(例,nextval[i]=nextval[3]);若不相等,则nextval[i]=next[i](例,nextval[i]=next[i]=3)。
0 0
- Next数组的计算
- next数组计算.
- KMP算法Next数组计算
- KMP算法Next数组计算
- KMP算法Next数组计算
- KMP算法next数组计算
- KMP算法Next数组计算
- KMP算法Next数组计算
- KMP算法的next、next value数组的手工计算
- KMP算法(重点next数组计算)
- KMP算法的next数组计算原理
- KMP算法计算next数组 匹配字符串
- KMP算法next数组计算--字符串方式
- KMP算法next数组的计算
- 手动计算KMP算法的Next数组与NextVal数组
- KMP算法中next数组、nextval数组的手工计算
- KMP算法中特征值数组next的计算与使用
- 字符串匹配问题——next数组计算
- Photoshop USM (Unsharp Mask)锐化算法OpenCV实现
- (转自xiaoquanhuang)*openGL中调用着色器的一般步骤
- JavaEE_POI导出Excel, 设置导出Excel 单元格样式
- iOS block 的用法
- jpa
- next数组计算.
- Android中的Shape使用总结
- Lua和C++交互详细总结
- 堆排序的实现
- 3572: [Hnoi2014]世界树 虚树+DP
- 正交设计
- jenkins 自动构建项目
- maven "Generating project in Batch mode"问题的解决,archetype-catalog.xml
- 解决问题的三个办法,分先后