第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

我這樣寫的KMP算法哪里錯(cuò)了呢?

我這樣寫的KMP算法哪里錯(cuò)了呢?

C
qq_thinginginli_0 2016-11-13 21:44:43
#include?<stdio.h> #include?<string.h> int?main() { ?int?next[30]; ?int?i=1,j=0; ?char?list[30]?="abc"; ?char?goal[100]="abdabce"; ?next[0]=-1; ?next[1]=0; ?int?lenlist=strlen(list); ?while(i<lenlist) ?{ ??if(j==0?||?list[i]==list[j]) ??{??????? ???i++; ???j++; ???next[i]=j; ??} ??else ??{ ???j=next[j]; ??} ?} ?for(i=0;i<=lenlist;i++) ?{ ??printf("%d?",next[i]); ?} ?i=0; ?j=0; ?while(list[j]?&&?goal[i]) ?{?????? ??if(list[i]==goal[j])? ??{ ???i++; ???j++; ??} ??else?if(j==-1) ??{ ???i++; ???j++; ??} ??else ??{ ???j=next[j]; ??} ?} ?printf("j=%d?",j); ?if(j==lenlist) ?{ ??printf("包含"); ?} ?else ?{ ??printf("不包含"); ?}? ?return?0; }
查看完整描述

2 回答

已采納
?
Yexiaomo

TA貢獻(xiàn)152條經(jīng)驗(yàn) 獲得超157個(gè)贊

曉得了,

還是 31 行 的 while() 循環(huán)體寫錯(cuò)了

把 ?if( list[i] == goal[j] ) --->改為 ?if( list[j] == goal[i] ) ?

然后就可以了,....

-----

這個(gè)錯(cuò)誤很明顯吧, ?個(gè)人理解-->(下標(biāo) j 對(duì)應(yīng) ?模式串(--> 同時(shí) 對(duì)應(yīng)于 next 數(shù)組, j 的變化 編制下一個(gè) 與 目標(biāo)串 匹配的位置)?)

第一次沒有看出來, 尷尬...?


幸虧又看了一遍

查看完整回答
2 反對(duì) 回復(fù) 2016-11-22
?
Yexiaomo

TA貢獻(xiàn)152條經(jīng)驗(yàn) 獲得超157個(gè)贊

用?KMP算法?求?next數(shù)組??沒有寫錯(cuò)
錯(cuò)在了?匹配時(shí),?
31行?的?while()循環(huán)體?寫錯(cuò)誤了(錯(cuò)誤原因不知道為啥),?代碼改為下面這個(gè)
if(j?==?0?||?goal[i]?==?list[j]){?
????++i;
????++j;
}else{			
????j?=?next[j];	
}


查看完整回答
1 反對(duì) 回復(fù) 2016-11-22
  • 2 回答
  • 1 關(guān)注
  • 1294 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)