数据结构模式匹配算法.docx

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
特记下: # ?. H? I9 w6 S% {* Q9 tint get_nextval(SString T,int &nextval[ ]){4 `2 B? ?2 k: r+ Y5 g: q" x ? ? ? ? ? ?//求模式串T的next函数修正值并存入数组nextval。 7 o" ], W2 z, X0 n+ G? ? ? ? ? ?i=1; nextval[1]=0; j=0;" U2 g: c2 i( o: D; l ? ? ? ? ? ?while(i<T[0]){ # P: D( c0 H4 d& x: [0 o+ D0 ^( y? ? ? ? ? ? ? ?if(j==0||T==T[j]){ $ }- H' W/ y? X; B? ? ? ? ? ? ? ? ? ++i;++j;* ~: u" d2 j; O0 J+ p# r/ f ? ? ? ? ? ? ? ? ? if (T!=T[j]) nextval=j; % \& c, |& q0 i# j) a( p1 k? ? ? ? ? ? ? ? ? else nextval=nextval[j];5 g3 D% p? ]; y' s& l- p% o3 B) _2 H ? ? ? ? ? ? ? ?} # Y* t% S? N. |! Z# O0 C? ? ? ? ? ? ? ?else j=nextval[j]; 4 e? a) W9 r$ \* f1 G8 a? i2 t) c? ? ? ? ? ?}# m# P+ ?3 a; l. N, P2 g& b ? ? ? }//get_nextval ; ?. x8 T3 M- Z4 B) i? ? ? 根据这段程序来求nextval的值是可以方便计算出来,但如果是应付考研试题或者期末考试就有点麻烦了。而如果记住我推荐的方法,那么任何时候都可以很方便地求解nextval了。 / u8 G9 {- }" k% W2 r4 C0 S6 E? ? ? 首先看看next数组值的求解方法。 - k3 S1 a" t3 k8 T& X, U? ? ? 例如: 模式串 a b a a b c a c next值 0 1 1 2 2 3 1 2 nextval值 ; ]8 Q$ k& D3 h# W9 l ? T9 y? r& b- @+ w 1 j1 U) Z" i# Q! [ - x6 F9 w5 _9 R9 Y7 E 0 a7 z* k, A5 |5 s9 W ) K2 w& U. |& H! A% W1 ]" ~' { $ O3 D; m3 G; U/ P4 V6 k" H & U! F) Z, K5 ~2 [$ H0 d6 } next数组的求解方法是:第一位的next值为0,第二位的next值为1,后面求解每一位的next值时,根据前一位进行比较。首先将前一位与其next值对应的内容进行比较,如果相等,则该位的next值就是前一位的next值加上1;如果不等,向前继续寻找next值对应的内容来与前一位进行比较,直到找到某个位上内容的next值对应的内容与前一位相等为止,则这个位对应的值加上1即为需求的next值;如果找到第一位都没有找到与前一位相等的内容,那么需求的位上的next值即为1。! \# W2 ?3 `; p3 i: Z# S ? ? ? 看起来很令人费解,利用上面的例子具体运算一遍。 * @# [5 T' p, e; o" K% J? ? ? 1.前两位必定为0和1。; y1 v? l+ W/ O. Q ? ? ? 2.计算第三位的时候,看第二位b的next值,为1,则把b和1对应的a进行比较,不同,则第三位a的next的值为1,因为一直比到最前一位,都没有发生比较相同的现象。& B, O7 i7 |? `% ~! J* `. t ? ? ? 3.计算第四位的时候,看第三位a的next值,为1,则把a和1对应的a进行比较,相同,则第四位a的next的值为第三位a的next值加上1。为2。因为是在第三位实现了其next值对应的值与第三位的值相同。 8 Q; V% |2 w8 }2 f; s# [6 O3 s1 ~? ? ? 4.计算第五位的时候,看第四位a的next值,为2,则把a和2对应的b进行比较,不同,则再将b对应的next值1对应的a与第四位的a进行比较,相同,则第五位的next值为第二位b的next值加上1,为2。因为是在第二位实现了其next值对应的值与第四位的值相同。 % l2 [- V/ F9 [# ]? ? ? 5.计算第六位的时候,看第五位b的next值,为2,则把b和2对应的b进行比较,相同,则第六位c的next值为第五位b的next值加上1,为3,因为是在第

文档评论(0)

乾道嘉777 + 关注
官方认证
内容提供者

该用户很懒,什么也没介绍

认证主体廊坊涵淇网络科技有限公司
IP属地河北
统一社会信用代码/组织机构代码
91131025MA7BUE2JX3

1亿VIP精品文档

相关文档