




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、實(shí)驗(yàn)報(bào)告一串匹配問題班級:_計(jì)算機(jī)師_ 學(xué)號:2姓名:_一、實(shí)驗(yàn)題目:給定一個(gè)文本,在該文本中查找并定位任意給定字符串。二、實(shí)驗(yàn)?zāi)康?(1) 深刻理解并掌握蠻力法的設(shè)計(jì)思想;(2) 提高應(yīng)用蠻力法設(shè)計(jì)算法的技能;(3) 理解這樣一個(gè)觀點(diǎn):用蠻力法設(shè)計(jì)的算法,一般來說,經(jīng)過適度的努力后, 都可以對算法的第一個(gè)版本進(jìn)行一定程度的改良,改進(jìn)其時(shí)間性能。三、實(shí)驗(yàn)要求:(1) 實(shí)現(xiàn)BF算法;(2) 實(shí)現(xiàn)BF算法的改進(jìn)算法:KMP 算法和BM算法;(3) 對上述3個(gè)算法進(jìn)行時(shí)間復(fù)雜性分析,并設(shè)計(jì)實(shí)驗(yàn)程序驗(yàn)證分析結(jié)果。四、算法描述(對算法主要部分進(jìn)行偽代碼描述或畫出流程圖)BF算法:基本思想:從主串S的第一
2、個(gè)字符開始和模式T的第一個(gè)字符進(jìn)行比較,若相等, 則繼續(xù)比較兩者的后續(xù)字符;若不相等,則從主串S的第二個(gè)字符開始和模式T的第一個(gè)字符進(jìn)行比較,重復(fù)上述過程,若 T中的字符全部比較完畢,貝U說明本趟匹配成功; 若最后一輪匹配的起始位置是 n-m則主串S中剩下的字符不足夠匹配整個(gè)模式 T,匹 配失敗。這個(gè)算法稱為樸素的模式匹配算法,簡稱BF算法。KMP算法:基本思想:1. 在串S和串T中分別設(shè)比較的起始下標(biāo)i和j ;2. 循環(huán)直到S中所剩字符長度小于T的長度或T中所有字符均比較完畢2.1如果Si=Tj,則繼續(xù)比較S和T的下一個(gè)字符;否則2.2將j向右滑動(dòng)到nextj位置,即j=nextj;2.3如
3、果j=0,則將i和j分別加1,準(zhǔn)備下一趟比較;2.4如果T中所有字符均比較完畢,則返回匹配的起始下標(biāo);否則返回0;BM算法:基本思想:BM算法與KMP算法的主要區(qū)別是匹配操作的方向不同。雖然 BM算法僅 把匹配操作的字符比突順序改為從右向左,但匹配發(fā)生失敗時(shí),模式 T右移的計(jì)算方法 卻發(fā)生了較大的變化。0 a0 b0 z模式T長模式T長i減1i+DIST(T,S1 r五、實(shí)驗(yàn)結(jié)果與結(jié)論:(給出測試數(shù)據(jù)以及程序運(yùn)行結(jié)果,并進(jìn)行比較,得出自己的結(jié)論)設(shè)計(jì)思想:設(shè)文本串T,模式串為P。首先將T與P進(jìn)行左對齊,然后進(jìn)行從右向 左比較,若是某趟比較不匹配時(shí),BM算法就采用兩條啟發(fā)式規(guī)則,即壞字符規(guī)則和好
4、后 綴規(guī)則,來計(jì)算模式串向右移動(dòng)的距離,直到整個(gè)匹配過程的結(jié)束。BE算法:#in elude #in elude #in elude main ()char s100;char t100;int i,a,b,m,n;prin tf(*please in put a stri ng:);sca nf(%s,s);prin tf(please in put search stri ng:);sca nf(%s,t);m=strle n(s);n=strle n(t);printf( *for(i=0;im;i+)b=0;a=i;while(s a=tb &b!=n)a+; b+; if(b=n)口
5、prin tf(success!n);return 0;printf(no found!:%snn,&t);return 0;KMP算 法:#in clude #in clude #in clude mai n()char s100;char t100;int i,a,b,m,n;MMMMMplease input a string=123456789 kilease input srearch 生七:=的MiXX XX xmtRF其莫舅其貨料算其success fTress any to continueprin tf(*please in put a stri ng:); scan f(%
6、s,s);prin tf(please in put search stri ng:); scan f(%s,t);m=strle n(s);n=strle n(t);prin tf(*KMP*n) for(a=0;a=m-n; a+) b=0;while(sa=tb &b!=n)a+;b+;if(b=n)prin tf(success!n);return 0;elseb=b+1; a=a-b;if(b=-1)b+;else return 0;printf(no found!:%snn,&t); return 0;BM算法:#in clude using n amespace std;#in
7、clude #in clude static int time=0;/dist 函數(shù)int dist(char ch,char *T)int k=-1,t1;t1=strle n(T);for(int i=0;it1-1;i+)if(ch=Ti&i t1) k=i+1;if(ch=Ti&i=t1-1) k=0;if(k=-1)k=0;retur nt1-k;void BM(char *S,char *T)int s1,t1;s仁 strle n(S);t1=strle n(T);int j,i=t1-1;while(i=0&Si=Tj)i-;j-;if(j=-1)coutvv該串從第&位開始匹配:i+2=s1)cout 匹配不成功S;coutvv請輸入串T:;cin T;coutBM 算法:;BM(S,T);coutvv 一共執(zhí)行循環(huán)vvtimevv次endl;OXUse rsAdnnini stratorDe&ktopA.AABH串 I
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 軟件開發(fā)環(huán)境配置試題及答案
- 深入探討軟件版本控制技術(shù)試題及答案
- VB考試指導(dǎo)試題及答案
- 2025屆江蘇省興化市實(shí)驗(yàn)學(xué)校數(shù)學(xué)七下期末經(jīng)典模擬試題含解析
- VB基礎(chǔ)鞏固試題及答案
- 軟考數(shù)據(jù)保護(hù)與恢復(fù)計(jì)劃試題及答案
- 法學(xué)概論及其應(yīng)用領(lǐng)域試題及答案
- 2025年中國造紙輥市場調(diào)查研究報(bào)告
- 2025屆浙江省臺州市第四協(xié)作區(qū)七下數(shù)學(xué)期末質(zhì)量檢測試題含解析
- 2025年中國褪色筆市場調(diào)查研究報(bào)告
- (小學(xué))語文教師書寫《寫字教學(xué)講座》教育教研講座教學(xué)培訓(xùn)課件
- 高血壓和心血管疾病的預(yù)防與管理
- 小學(xué)數(shù)學(xué)-水中浸物問題-完整版題型訓(xùn)練30題-帶答案
- 中國大學(xué)生積極心理品質(zhì)量表
- 2023充電樁停車場租賃合同 充電樁租地合同正規(guī)范本(通用版)
- 淺談屢查屢犯問題的成因及對策
- 八年級下冊Unit-4復(fù)習(xí)課
- 神經(jīng)病學(xué)人衛(wèi)版習(xí)題集+期末試卷
- 車輛違章處理委托書委托書
- 氮化爐安全操作規(guī)程
- 初中物理電功率高低溫檔專題解析課件
評論
0/150
提交評論