设主串S='abcdabcababcba',子串t='ababab',求解以下问题:求出模式T的Next[]值

求出模式T的NextVal[]值。给出在S中查找T的详细匹配过程,并指出最少需要几次比较?... 求出模式T的NextVal[]值。给出在S中查找T的详细匹配过程,并指出最少需要几次比较? 展开
 我来答
勤奋的哈七八答
高粉答主

2020-06-02 · 醉心答题,欢迎关注
知道小有建树答主
回答量:262
采纳率:100%
帮助的人:5万
展开全部

过点D作DE⊥AB于点E,过点C作CF⊥AB于点F,

梯形ABCD中,AB∥CD,∠DAB=∠CBA=45°,DE=CF,

在△ADE和△BCF中,∠DAE=∠CBF∠DEA=∠CFB=90°DE=CF    

△ADE≌△BCF(AAS),AE=BF,∵AB=10cm,CD=4cm,

AE=BF=3cm,△ADE是等腰直角三版角形,DE=AE=3cm,

当直线PM过点D点时,AM=AE=3cm,t=MN+AM=3+5=8(s);当0<权t<5时,y=1    2

扩展资料:

从目标串s=“s0s1...sn-1”的第一个字符开始和模式串t="t0t1...tm-1"中的第一个字符比较,若相等,则继续逐个比较后续字符,否则从目标串s的第二个字符开始重新与模式串t的第一个字符进行比较;

以此类推,若从模式串s的第i个字符开始,每个字符依次和目标串t中的对应字符相等,则匹配成功,返回i,否则,匹配失败,返回-1。

采用BF算法进行模式匹配的过程如图所示。首先i,j分别扫描主串和模式串。i=0,j=0,当前字符相同时均增1,匹配到i=2,j=2失败为止,修改i=i-j+1=1(回溯到前面),j=0,...;

继续这一过程直到i=4,j=0,这时所有字符均相同,i,j递增到模式串扫描完毕,此时i=10,j=5,返回i-t.length=5,表示t是s的子串,且位置为5。

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式