《嚴(yán)蔚敏數(shù)據(jù)結(jié)構(gòu)》PPT課件.ppt

上傳人:san****019 文檔編號(hào):20150357 上傳時(shí)間:2021-02-22 格式:PPT 頁(yè)數(shù):22 大?。?05.61KB
收藏 版權(quán)申訴 舉報(bào) 下載
《嚴(yán)蔚敏數(shù)據(jù)結(jié)構(gòu)》PPT課件.ppt_第1頁(yè)
第1頁(yè) / 共22頁(yè)
《嚴(yán)蔚敏數(shù)據(jù)結(jié)構(gòu)》PPT課件.ppt_第2頁(yè)
第2頁(yè) / 共22頁(yè)
《嚴(yán)蔚敏數(shù)據(jù)結(jié)構(gòu)》PPT課件.ppt_第3頁(yè)
第3頁(yè) / 共22頁(yè)

下載文檔到電腦,查找使用更方便

9.9 積分

下載資源

還剩頁(yè)未讀,繼續(xù)閱讀

資源描述:

《《嚴(yán)蔚敏數(shù)據(jù)結(jié)構(gòu)》PPT課件.ppt》由會(huì)員分享,可在線閱讀,更多相關(guān)《《嚴(yán)蔚敏數(shù)據(jù)結(jié)構(gòu)》PPT課件.ppt(22頁(yè)珍藏版)》請(qǐng)?jiān)谘b配圖網(wǎng)上搜索。

1、第 4章 串( String) 4.1 串類型的定義 4.2 串的表示和實(shí)現(xiàn) 4.3 串的模式匹配算法 記為: s = a1 a2 . a n (n0 ) 串名 串值(用 括起來) 串 即字符串,是由零個(gè)或多個(gè)字符組成的 有限 序列, 是 數(shù)據(jù) 元素為單個(gè)字符 的特殊線性表。 4.1 串類型的定義 隱含結(jié)束符 0 ,即 ASCII 碼 NULL 為何要單獨(dú)討論串類型? 1) 字符串操作比其他數(shù)據(jù)類型更復(fù)雜(如拷貝、連接操作) 2) 程序設(shè)計(jì)中,處理對(duì)象很多都是串類型。 若干術(shù)語: 串長(zhǎng): 串中字符的個(gè)數(shù)( n0 ) . n=0 時(shí)稱為空串 。 空白串: 由一個(gè)或多個(gè) 空格符 組成的串。 問:空

2、串和空白串有無區(qū)別? 答: 有區(qū)別。 空串 (Null String)是指長(zhǎng)度為零的串; 而空白串 (Blank String),是指包含一個(gè)或多 個(gè)空白字符 (空格鍵 )的字符串 . 子串: 子串位置: 字符位置: 串相等: 例 1: 現(xiàn)有以下 4個(gè)字符串: a =BEI b =JING c = BEIJING d = BEI JING 問: 他們各自的長(zhǎng)度? a是 c和 d的子串,在 c和 d中的位置都是 1 串 S中 任意個(gè)連續(xù)的字符 序列叫 S的子串 ; S叫 主串 。 子串的第一個(gè)字符在主串中的序號(hào)。 字符在串中的序號(hào)。 串長(zhǎng)度相等,且對(duì)應(yīng)位置上字符相等。 a是哪個(gè)串的子串?在主串中

3、的位置是多少? a =3, b =4, c = 7, d=8 “空串是任意串的子串;任意串 S都是 S本身的子串,除 S本身 外, S的其他子串稱為 S的 真子串 。 ” 數(shù)據(jù)結(jié)構(gòu)與算法 中山大學(xué)出版社 空串是哪個(gè)串的子串? a是不是自己的子串? C語言中已有類似串運(yùn)算函數(shù)! ADT String Objects: D=ai | ai CharacterSet, i=1, 2, , n, n0 Relations: R1= | ai-1,ai D, i=2, , n functions: /至少有 13種基本操作 StrAssign( 求串長(zhǎng): int strlen(char *s); 串連接

4、: char strcat(char *to,char *from) 子串 T定位: char strchr(char *s,char *c); 注:用 C處理字符串時(shí),要調(diào)用標(biāo)準(zhǔn)庫(kù)函數(shù) #include 類 C StrCompare(S,T) StrLength(S) Concat( /P73 SString s; /s 是一個(gè)可容納 255個(gè)字符的順序串。 注: 一般用 SString0來存放 串長(zhǎng) 信息(如 pascal語言); C語言約定在串尾加結(jié)束符 0,以利操作加速,但不 計(jì)入串長(zhǎng) (用首址和串長(zhǎng)、或首址和尾標(biāo)記來描述串?dāng)?shù) 組) 若字符串超過 Maxstrlen 則自動(dòng)截?cái)?(因?yàn)?/p>

5、靜態(tài)數(shù)組存不 進(jìn)去)。 例: 用 順序存儲(chǔ)方式 編寫 求子串函數(shù) SubString( /若 pos和 len參數(shù)越界,則告警 Sub1 len=Spos pos+len-1; Sub0=len; return OK; 將串 S中從第 pos個(gè)字符開始、長(zhǎng)度為 len的字符序列復(fù)制到串 Sub中。 (注:考慮到函數(shù)的通用性,應(yīng)當(dāng)讓串 Sub的預(yù)留長(zhǎng)度與 S一樣) 子串長(zhǎng)度 s = a1 a2 . a n pos len Sub 討論:想存放 超長(zhǎng) 字符串怎么辦? 改用 動(dòng)態(tài)分配 的一維數(shù)組 堆 思路: 利用 malloc函數(shù)合理預(yù)設(shè)串長(zhǎng)空間。 特點(diǎn): 若在操作中串值改變,還可以利用 reall

6、oc函數(shù) 按新串長(zhǎng)度 增加空間 (即動(dòng)態(tài)數(shù)組概念) 。 Typedef struct char *ch; /若非空串 ,按串長(zhǎng)分配空間 ; 否則 ch=NULL int length; /串長(zhǎng)度 HString 堆分配存儲(chǔ)特點(diǎn): 仍用一組連續(xù)的存儲(chǔ)單元來存放串,但 存儲(chǔ)空間是在程序執(zhí)行過程中 動(dòng)態(tài)分配 而得。 堆 T的存儲(chǔ)結(jié)構(gòu)描述: T.ch T.length C是指針變量,可以自增! 意即每次后移一個(gè)數(shù)據(jù)單 元。 直到終值為 “ 假 ” 停止,串尾特征是 c 0 NULL 0 Status StrAssign(HString /釋放 T原有空間 for (i=0, c=chars; c; +

7、i, +c); /求 chars的串長(zhǎng)度 i 例 1: 編寫 建堆函數(shù) (參見教材 P76) 此處 T.ch0沒有 用來裝串長(zhǎng),因?yàn)?另有 T.length 分 量 if ( !i ) T.ch = NULL; T.length = 0; else if (!(T.ch = (char*)malloc( i *sizeof(char) exit(OVERFLOW); T.ch0.i-1 = chars0.i-1; T.length =i; Return OK; /StrAssign Status StrInsert ( HString /pos不合法則告警 if(T.length) /只要串

8、T不空,就需要重新分配 S空間,以便插入 T if (!( S.ch=(char*)realloc(S.ch, (S.length+T.length)*sizeof(char) ) exit(OVERFLOW); /若開不了新空間,則退出 for ( i=S.length-1; i=pos-1; -i ) S.chi+T.length = S.chi; / 為插入 T而騰出 pos之后的位置,即從 S的 pos位置起全部字符均后移 S.chpos-1pos+T.length -2 = T.ch0T.length -1; /插入 T,略 /0 S.length + = T.length; /刷新

9、 S串長(zhǎng)度 return OK; /StrInsert 例 2: 用 “ 堆 ” 方式編寫 串插入函數(shù) (參見教材 P75) 討論: 法 1存儲(chǔ)密度為 ;法 2存儲(chǔ)密度為 ; 顯然,若 數(shù)據(jù)元素很多,用法 2存儲(chǔ)更優(yōu) 稱為 塊鏈結(jié)構(gòu) 鏈?zhǔn)酱鎯?chǔ)特點(diǎn) : 用鏈表存儲(chǔ)串值,易插入和刪除。 法 1: 鏈表結(jié)點(diǎn)的數(shù)據(jù)分量長(zhǎng)度取 1(個(gè)字符) 法 2: 鏈表結(jié)點(diǎn)(數(shù)據(jù)域)大小取 n(例如 n=4) 1/2 9/15=3/5 A B C I NULL head head A B C D E F G H I # # # NULL 對(duì)塊鏈表的整體描述 #define CHUNKSIZE 80 /每塊大小,可由用

10、戶定義 typedef struct Chunk /首先定義結(jié)點(diǎn)類型 char ch CHUNKSIZE ; /每個(gè)結(jié)點(diǎn)中的數(shù)據(jù)域 struct Chunk * next ; /每個(gè)結(jié)點(diǎn)中的指針域 Chunk; 塊鏈類型定義: 塊鏈函數(shù)的編寫略 typedef struct /其次定義用鏈?zhǔn)酱鎯?chǔ)的串類型 Chunk *head; /頭指針 Chunk *tail; /尾指針 int curLen; /結(jié)點(diǎn)個(gè)數(shù) Lstring; /串類型只用一次,前面可以不加 Lstring 對(duì)每個(gè)結(jié)點(diǎn)的描述 算法目的: 確定主串中所含子串第一次出現(xiàn)的位置 ( 定位 ) 4.3 串的模式匹配算法 (屬于選講部分

11、) BF算法 (又稱古典的、經(jīng)典的、樸素的、窮舉的) KMP算法 算法種類: 帶回溯,速度慢 避免回溯,匹配速度快, 是全課程的亮點(diǎn)之一 定位問題稱為串的模式匹配 (Pattern Matching),即子串定位運(yùn) 算, 它是串處理系統(tǒng)中最重要的操作之一。 典型函數(shù)為 Index(S,T,pos), 見教材 P71 BF算法的實(shí)現(xiàn) 即編寫 Index(S,T,pos)函數(shù) 例 1: S=ababcabcacbab, T=abcac, pos=1, 求:串 T在串 S中第 pos個(gè)字符之后的位置。 利用 演示系統(tǒng) 看 BF算法執(zhí)行過程。 BF算法設(shè)計(jì)思想: 將主串 S的第 pos個(gè)字符和模式 T

12、的第 1個(gè)字符比較, 若 相等 ,繼續(xù)逐個(gè)比較后續(xù)字符; 若 不等 ,從主串 S的下一字符( pos+1)起,重新與 T第一 個(gè)字符比較。 直到主串 S的一個(gè)連續(xù)子串字符序列與模式 T相等。返回值 為 S中與 T匹配的子序列 第一個(gè)字符的序號(hào) ,即匹配成功。 否則,匹配失敗,返回值 0 . Int Index(SString S, SString T, int pos) i=pos; j=1; while ( i=S0 /子串結(jié)束,說明匹配成功 else return0; /Index 例 2: S=ababcabcacbab, T=abcac, 求 Index(S,T,5) (參見教材 P7

13、9) 相當(dāng)于子串向右滑動(dòng)一個(gè)字符位置 匹配成功后指針仍要回溯!因?yàn)橐祷氐?是被匹配的首個(gè)字符位置。 i j S=a b a b c a b c a c b a b T=a b c a c pos=5 討論: 若 n為主串長(zhǎng)度, m為子串長(zhǎng)度,則串的 BF匹配算法最壞的情 況下需要比較字符的總次數(shù)為 (n-m+1)*m O(n*m) 一般的情況是: O(n+m) 推導(dǎo)方法: 要從最好到最壞情況統(tǒng)計(jì)總的比較次數(shù),然后 取平均。 BF算法的時(shí)間復(fù)雜度 最好的情況是: 一配就中! 只比較了 m次。 能否利用已 部分匹配過 的信息而加快模式串的滑動(dòng)速度? 能! 而且主串 S的指針 i不必回溯 !最壞情況也能達(dá)到 O(n+m) 請(qǐng)看 KMP算法! 最惡劣情況是: 主串前面 n-m個(gè)位置都 部分匹配 到子串的最后 一位,即這 n-m位比較了 m次,別忘了最后 m位也各比較了一次, 還要加上 m!所以總次數(shù)為: (n-m)*m+m (n-m+1)*m KMP算法 (特點(diǎn):速度快) KMP算法設(shè)計(jì)思想 KMP算法的推導(dǎo)過程 KMP算法的實(shí)現(xiàn) (關(guān)鍵技術(shù) :計(jì)算 nextj) KMP算法的時(shí)間復(fù)雜度 全書一大亮點(diǎn)!

展開閱讀全文
溫馨提示:
1: 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
5. 裝配圖網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

相關(guān)資源

更多
正為您匹配相似的精品文檔
關(guān)于我們 - 網(wǎng)站聲明 - 網(wǎng)站地圖 - 資源地圖 - 友情鏈接 - 網(wǎng)站客服 - 聯(lián)系我們

copyright@ 2023-2025  zhuangpeitu.com 裝配圖網(wǎng)版權(quán)所有   聯(lián)系電話:18123376007

備案號(hào):ICP2024067431號(hào)-1 川公網(wǎng)安備51140202000466號(hào)


本站為文檔C2C交易模式,即用戶上傳的文檔直接被用戶下載,本站只是中間服務(wù)平臺(tái),本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)上載內(nèi)容本身不做任何修改或編輯。若文檔所含內(nèi)容侵犯了您的版權(quán)或隱私,請(qǐng)立即通知裝配圖網(wǎng),我們立即給予刪除!