版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、實驗報告一 串匹配問題班級: _計算機(jī)師 _ 學(xué) 號: 2 姓 名: _一、實驗題目 :給定一個文本 , 在該文本中查找并定位任意給定字符串。二、實驗?zāi)康模?1) 深刻理解并掌握蠻力法的設(shè)計思想 ;(2) 提高應(yīng)用蠻力法設(shè)計算法的技能 ;(3) 理解這樣一個觀點(diǎn) : 用蠻力法設(shè)計的算法 , 一般來說 , 經(jīng)過適度的努力后 , 都可以對算法的第一個版本進(jìn)行一定程度的改良 , 改進(jìn)其時間性能。三、實驗要求:(1) 實現(xiàn) BF 算法 ;(2) 實現(xiàn) BF 算法的改進(jìn)算法 : KMP 算法和 BM 算法 ;(3) 對上述 3 個算法進(jìn)行時間復(fù)雜性分析 , 并設(shè)計實驗程序驗證分析結(jié)果。四、算法描述 (對
2、算法主要部分進(jìn)行偽代碼描述或畫出流程圖) BF算法:基本思想:從主串 S的第一個字符開始和模式 T 的第一個字符進(jìn)行比較,若相等, 則繼續(xù)比較兩者的后續(xù)字符;若不相等,則從主串 S的第二個字符開始和模式 T 的第一 個字符進(jìn)行比較,重復(fù)上述過程,若 T 中的字符全部比較完畢,則說明本趟匹配成功; 若最后一輪匹配的起始位置是 n- m,則主串 S 中剩下的字符不足夠匹配整個模式 T,匹 配失敗。這個算法稱為樸素的模式匹配算法,簡稱 BF 算法。KMP算法: 基本思想:1. 在串 S和串 T中分別設(shè)比較的起始下標(biāo) i 和 j ;2. 循環(huán)直到 S中所剩字符長度小于 T的長度或 T 中所有字符均比較
3、完畢 如果 Si=Tj ,則繼續(xù)比較 S和 T的下一個字符;否則 將 j 向右滑動到 nextj 位置,即 j=nextj ; 如果 j=0 ,則將 i 和j 分別加 1,準(zhǔn)備下一趟比較; 如果 T 中所有字符均比較完畢,則返回匹配的起始下標(biāo);否則返回0;BM算法:基本思想: BM算法與 KMP算法的主要區(qū)別是匹配操作的方向不同。雖然 BM算法僅把匹配操作的字符比突順序改為從右向左,但匹配發(fā)生失敗時,模式 T 右移的計算方法 卻發(fā)生了較大的變化。BF算法KMP算法五、實驗結(jié)果與結(jié)論: (給出測試數(shù)據(jù)以及程序運(yùn)行結(jié)果,并進(jìn)行比較,得出自己的結(jié)論)設(shè)計思想:設(shè)文本串 T,模式串為 P。首先將 T
4、與 P進(jìn)行左對齊,然后進(jìn)行從右向 左比較,若是某趟比較不匹配時, BM算法就采用兩條啟發(fā)式規(guī)則,即壞字符規(guī)則和好后 綴規(guī)則,來計算模式串向右移動的距離,直到整個匹配過程的結(jié)束。BE算法:#include <>#include <>#include <>main()char s100;char t100;int i,a,b,m,n;printf("*please input a string:"); scanf("%s",s);printf("please input search string:")
5、; scanf("%s",t);m=strlen(s); n=strlen(t);printf( "*for(i=0;i<m;i+)b=0;a=i;while(sa=tb&&b!=n)a+; b+;if(b=n)printf("success!n"); return 0;printf("no found!:%snn",&t); return 0;KMP算法:#include <>#include <>#include <> main()char s100;ch
6、ar t100;int i,a,b,m,n; printf("*please input a string:"); scanf("%s",s);printf("please input search string:");scanf("%s",t);m=strlen(s); n=strlen(t);printf("*KMP*n");for(a=0;a<=m-n;a+)b=0;while(sa=tb&&b!=n)a+;b+;if(b=n)printf("success
7、!n");return 0;elseb=b+1;a=a-b; if(b=-1) b+; else return 0;printf("no found!:%snn",&t); return 0;BM算法:#include <iostream> using namespace std;#include <>#include <> static int time=0;/dist 函數(shù)int dist(char ch,char *T)int k=-1,t1; t1=strlen(T);for(int i=0;i<t1-1;
8、i+)if(ch=Ti&&i<t1)k=i+1;if(ch=Ti&&i=t1-1) k=0; if(k=-1)k=0;returnt1-k;void BM(char *S,char *T)int s1,t1;s1=strlen(S);t1=strlen(T);int j,i=t1-1;while(i<s1)j=t1-1;while(j>=0&&Si=Tj)j-;if(j=-1)cout<<" 該串從第 &i 位開始匹配: "<<i+2<<endl;break;els
9、etime+;i=i+dist(Si,T);if(i>=s1)cout<<" 匹配不成功 "<<endl;void main() cout<<" 請輸入串 S:"int *next=new int;/給 next 指針分配空間char *S=new char;/給 S 指針分配空間char *T=new char;/給 T 指針分配空間cin>>S;cout<<" 請輸入串 T:"cin>>T;cout<<"BM 算法: "BM(S,T);cout&l
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 快遞運(yùn)輸合同模板
- 建筑民工勞務(wù)協(xié)議
- 2024版樣機(jī)試制合作協(xié)議
- 2024年出租車租車合同模板
- 懷孕期間夫妻分手協(xié)議
- 城市軌道交通工程建筑信息模型(BIM)分類與編碼標(biāo)準(zhǔn)
- 建筑行業(yè)標(biāo)準(zhǔn)腳手架租賃合同
- 2024項目投資合同撰寫要點(diǎn)
- 購買混凝土合同范本
- 生物中圖版自主訓(xùn)練:第三單元第一章第一節(jié)遺傳物質(zhì)的發(fā)現(xiàn)
- 2023年上海機(jī)場集團(tuán)有限公司校園招聘筆試題庫及答案解析
- 鏡頭的角度和方位課件
- 污水處理常用藥劑簡介知識講解課件
- 五年級上冊英語課件-Unit 1《My future》第1課時牛津上海版(三起) (共28張PPT)
- 光交接箱施工規(guī)范方案
- 氣溫和降水學(xué)案
- 普及人民代表大會制度知識競賽試題庫(1000題和答案)
- 國家電網(wǎng)公司施工項目部標(biāo)準(zhǔn)化管理手冊(2021年版)線路工程分冊
- 《汽車低壓線束設(shè)計規(guī)范》
- 工程項目增加簽證單
- 被一部電影感動記韓國電影《鳴梁海戰(zhàn)》觀后感
評論
0/150
提交評論