版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、數據結構實驗報告實驗名稱串班級0901姓名髙傲學號20091185015日期2011 12 8實驗目的:(1)掌握順序串的各種基本運算(2)掌握模式匹配算法實驗內容:2.1編寫一個程序algo3-l.cpp,實現順序串的各種基本運算,并在此基礎上設訃一個主函數 完成如下功能:(1)建立串 s=wabcdefghefghijklmnw和串 sWxyz;(2)輸出串s:(3)輸出串s的長度:(4)在串s的第9個字符位置插入串si而產生串s2:(5)輸出串s2:(6)刪除串s第2個字符開始的5個字符而產生串s2:(7)輸出串s2:(8)將串s第2個字符開始的5個字符替換成串si而產生串s2:(9)輸
2、出和串s2.(10)提取串s的第2個字符開始的10個字符而產生串S3:(11)輸出串S3:(22)將串si和串s2連接起來而產生串s4:(13)輸出串s4.程序源代碼:2. 1的源程序:Sinclude Sdefine MAXSIZE 256 /char sMAXSIZE;/求串長int StrLength(char *s) int i二0;while(si != 0)i+;return (i);/串聯(lián)接int StrConcat(char *si, char *s2, char *s)int i二0, j, lenlF len2;lenl= StrLength(sl);len2= StrLe
3、ngth(s2);if(lenl+len2 MAXSIZE-1)return (0);j 二0;wh 訂 e(slj!= or)si=slj;i+;j+;j 二0; while(s2j!= 0F)si=s2j;i+;j+;si二P;return (1);/求子串int StrSub(char *tf char *s, int i, int len) int slen,j; slen=StrLength(s);if(islen lenslen-i+l) printf(-參數不對0; return (0); for(j=0; jlen; j+)tj=si+j-l;tj= 0;return (1);
4、/串比較int StrCmp(char *sl, char *s2)int i二0;while(sli = s2i & sli!=0) i+;return (sli二二 s2i);/輸岀串void Disp_Str(char *s)int i;for(i=0;iStrLength(s);i+)printfsi); printf(n);插入串并保存到新串中int Strinsert (char *s, char * si, int i, char *s2) int j二0, k, lensl, lens; lens=StrLength(s);lensl=StrLength(si);for(k=0
5、; ki-l; k+) s2j=sk;j+;for(int 1=0; Klensl; 1+)s2j=sll;j+;for(int m二k; mlens; m+)s2j=sm; j+;s2j二0;return (1);刪除串中元素并保存到新串中int StrDelete(char *s, char *s2, int a, int b) int i二0, lens=StrLength(s);for(int j二0; j (a-1); j+)s2i=sj;i+;for(int k=(a+b-l); klens; k+)s2i=sk;i+;s2i= 0;return (1);用一個串替代另一個串中部分
6、字符并保存到新串中int TiDaiStr(char *s, char *si, char *s2, int a, int b) int i二0, lens, lensl; lens=StrLength(s); lensl=StrLength(si);for (int j二0; ja-l; j+)s2i=sj;i+;for(int k=0; klensl; k+)s2i=slk;i+;for(int l=(a+b-1); Klens; 1+) s2i=sl;i+;s2i= 0;return (1);int main(void)printf C (1)建立串 s=abcdefghefghi jk
7、lmn 和 sl=xyzn?,);char sMAXSIZE =,zabcdefghefghijklmn;char siMAXSIZE二xyz;printf C (2)輸出串 s二);Disp_Str (s);printf (,z (3)輸出串 s 的長度:%dn* StrLength(s);printf C (4)在串s的第9個字符位置插入串si而產生s2n);char s2MAXSIZE;Strinsert (s, si, 9, s2);printf C (5)輸出串 s2二);Disp_Str (s2);printf C (6)刪除串s第2個字符開始的5個字符而產生串s2n);StrDe
8、lete(s, s2, 2, 5);printf (,? (7)輸出串 s2:);Disp_Str (s2);printf (8)將串s第2個字符開始的5個字符替換成串si而產生串s2n);TiDaiStr (s, si, s2, 2, 5);printf C (9)輸出 s2二);Disp_Str (s2);printf (w (10)提取串s的第2個字符開始的10個字符而產生串s3n);printf (* (11)輸岀 s3二);char s3MAXSIZE;StrSub (s3, s, 2, 10);Disp_Str (s3);printf C (12)將串si和串s2連接起來而產生串s
9、4n);char s4MAXSIZE;StrConcat(si, s2t s4);printf C (13)輸岀串 s4O;Disp_Str (s4);getchar0;return(0);2.2#include#define maxsize 256 char smaxsize; char t100;int nextmaxsize;/求串長int StrLength(char *s)int i二0;while(si != 0)i+;return (i);int Change(char *s)int i;for(i=StrLength (s)-1; i=0; i-) si+l=si;s0=Str
10、Length (s);return (1);/簡單模式匹配int StrIndex_Bf(char *s, char *t)int i=l, j=l;while(i=sO&j=tO)if (si=tjj)i+;j卄;elsei=i-j+2;j二 1;辻 Gto)return (i-t.O);elsereturn T;/輸岀next值int Dis_next (int next, char *t)int i;for(i=l;i=t0;i+)printf (z/%dz,, next ZiJ);printf(n);return nexti;/模式串求next值void Getnext(char *t
11、,int next)int i=l, j=0;nextl=0;wh訂e(it0)if (j=0+i;+J;next LiJ =j;elsej=nextj;采用KMP算法求t在s中的位苣int SerIndex_KMP(char *s, char *t,int pos,int next) int i=pos, j=l;while (i=sO&jtO)returnelsereturn T;int main(void)printf C (1)建立 abcabcdabcdeabcdefabcdefg 目標串 s 和 abcdeabcdefab 模式串 tn);char s 匚=/,abcabcdabc
12、deabcdefabcdefg/;char t=?/abcdeabcdefabz,;Change (s);Change (t);printf (2)簡單模式匹配求 t 在 s 中的位置:%dn, StrIndex_Bf (s, t);printf (,z (3)由模式串 t 求出 next 值 next二);int nextmaxsize;Getnext(t, next);Dis_next(next, t);printf C (4)采用 KMP 算法求 t 在 s 中的位置:%dn, Serlndex.KMP(s, t, 1, next);2. 2源程序:#include#define max
13、size 256char smaxsize;char t100;int nextmaxsize;/求串長int StrLength(char *s)int i二0;wh訂e(si != 0)i+;return (i);int Change(char *s)int i;for(i=StrLength (s)-1; i=0; i)si+l=si;s E0=StrLength (s);return (1);/簡單模式匹配int StrIndex_Bf(char *s, char *t)int i=l, j=l;while(i=s0&jtO)return (i-t0); elsereturn -1;/
14、輸岀next值int Dis_next (int next, char *t) int i;for(i=l;i=t0;i+)printf (,z%d/z, next Li);printf(n); return nexti;/模式串求next值void Getnext(char *t,int next) int i=l, j=0;nextl=0; while(it 0)if(j=O ti=tj)+i;+J;nexti=j;else j=nextj; /采用KMP算法求t在s中的位置 int SerIndex_KMP(char *s, char *t,int pos,int next)int i=
15、pos,j=l;while(i=s0&jtol)return i-t;elsereturn -1;int main(void)printf C (1)建立 abcabcdabcdeabcdefabcdefg 目標串 s 和 abcdeabcdefab 模式串 tn);char s abcabcdabcdeabcdefabcdefg;char 二abcdeabcdefab;Change (s);Change (t);printf (2)簡單模式匹配求 t 在 s 中的位置:%dn, StrIndex_Bf (s, t);printf (,? (3)由模式串 t 求岀 next 值 next二);int nextmaxsize;Getnext(t, next);Dis_next(next, t);printf C (4)采用 KMP算法求 t 在 s 中的位置:%dn?z, SerIndex_KMP(s, t, 1, next) ;char getchar0;return(0);運行結果: H振結溝實驗c huana Igo2-l.exe建?7 串cdief uhi/iklmn 和 si2啪出串r :-二j z小一 3鐘出串3的長度:: #Ss的第9個宇符位畫插入串而產生s2 錨亠 6製瞬吳第2個字符開始的5個字符而產生串
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 【正版授權】 IEC 60335-2-61:2024 EN-FR Household and similar electrical appliances - Safety - Part 2-61: Particular requirements for thermal storage room heaters
- 2024年異戊橡項目建議書
- 2024年激光掃瞄顯微鏡項目建議書
- 全國2024年4月高等教育自考試市場營銷策劃試題含解析
- 2024~2025學年一年級語文上冊聲母與ün的拼讀
- 2024年液態(tài)食品包裝機械項目發(fā)展計劃
- 2024年血細胞分析儀器試劑項目建議書
- 北京市國電系統(tǒng)-2023年《通信安規(guī)》科目 單選題+多選題+判斷題+簡答題真題拔高卷3月份B卷
- 安徽省國家電網-2024年《通信安規(guī)》科目 單選題+多選題+判斷題+簡答題真題沖刺卷3月份B卷
- 2024年HGS紙用阻燃劑合作協(xié)議書
- 復旦大學中國古代文學研究中心(古籍所)《804中國古代文學》歷年考研真題匯編
- 員工晉升報名表
- 2023年黑龍江省面向清華大學定向選調應屆優(yōu)秀大學畢業(yè)生1204筆試歷年高頻考點試題含答案帶詳解
- 《測量基礎知識》課件
- 壓井施工單(直井)
- 6S管理課程講義課件
- 變頻器說明書大全
- 2023年檢察院法院書記員考試匯總
- 起搏器植入術后并發(fā)癥的預防和護理課件
- GB/T 1270-2023化學試劑六水合氯化鈷(氯化鈷)
- 國外的全科醫(yī)學畢業(yè)后教育課件
評論
0/150
提交評論