數(shù)據(jù)結(jié)構(gòu)4.ppt_第1頁
數(shù)據(jù)結(jié)構(gòu)4.ppt_第2頁
數(shù)據(jù)結(jié)構(gòu)4.ppt_第3頁
數(shù)據(jù)結(jié)構(gòu)4.ppt_第4頁
數(shù)據(jù)結(jié)構(gòu)4.ppt_第5頁
已閱讀5頁,還剩8頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、,數(shù)據(jù)結(jié)構(gòu) (DATA STRUCTURE),計(jì)算機(jī)科學(xué)與技術(shù)學(xué)院,2,第四章 串,串的定義 串的表示和實(shí)現(xiàn) 串的模式匹配算法,3,4.1 串類型的定義,字符串 (String):字符串是n ( 0 ) 個(gè)字符的有限序列,記作 S= “c1c2c3cn” 其中,S 是串名字 “c1c2c3cn”是串值 ci是串中字符 n 是串的長度。 串是字符串的簡稱。它是一種在數(shù)據(jù)元素的組成上具有一定約束條件的線性表,即要求組成線性表的所有數(shù)據(jù)元素都是字符,所以,人們經(jīng)常又這樣定義串:串是一個(gè)有窮字符序列。,4,子串、主串:串中任意連續(xù)的字符組成的子序列被稱為該串的子串。包含子串的串又被稱為該子串的主串。

2、例如,有下列四個(gè)串a(chǎn),b,c,d: a= “Welcome to Beijing” b= “Welcome” c= “Bei” d= “welcometo” 子串的位置:子串在主串中第一次出現(xiàn)的第一個(gè)字符的位置。 兩個(gè)串相等:兩個(gè)串的長度相等,并且各個(gè)對應(yīng)的字符也都相同。,5,ADT String 數(shù)據(jù)對象: D ai | aiChar, i=1,2,.,n, n0 數(shù)據(jù)關(guān)系:R1 |ai-1 ,aiD, i=2,.,n 基本操作: StrAssign ( ,7,第二種是在程序執(zhí)行過程中,利用標(biāo)準(zhǔn)函數(shù)malloc和free動(dòng)態(tài)地分配或釋放存儲字符串的存儲單元,并以一個(gè)特殊的字符作為字符串的結(jié)束

3、標(biāo)志,它的好處在于:可以根據(jù)具體情況,靈活地申請適當(dāng)數(shù)目的存儲空間,從而提高存儲資源的利用率。 不同的定義形式,算法中的處理也略有不同。,8,順序串存儲分配演示:,9,4.2.2 鏈?zhǔn)酱鎯Y(jié)構(gòu),由于串結(jié)構(gòu)中每個(gè)數(shù)據(jù)元素為一個(gè)字符,所以最直接的鏈?zhǔn)酱鎯Y(jié)構(gòu)是每個(gè)結(jié)點(diǎn)的數(shù)據(jù)域存放一個(gè)字符。舉例: 優(yōu)點(diǎn)是插入、刪除操作方便; 缺點(diǎn)是存儲密度較低。,10,若要將多個(gè)字符存放在一個(gè)結(jié)點(diǎn)中,就可以緩解上述問題。舉例: 由于串中的字符個(gè)數(shù)不一定是每個(gè)結(jié)點(diǎn)存放字符個(gè)數(shù)的整倍數(shù),所以,需要在最后一個(gè)結(jié)點(diǎn)的空缺位置上填充特殊的字符。 這種存儲形式優(yōu)點(diǎn)是提高了存儲密度;缺點(diǎn)是做插入、刪除字符的操作時(shí),可能會引起結(jié)點(diǎn)之間字符的移動(dòng),算法實(shí)現(xiàn)起來比較復(fù)雜。,11,4.3 串的模式匹配,定義 在串中尋找子串(第一個(gè)字符)在串中的位置 詞匯 在模式匹配中,子串稱為模式,串稱為目標(biāo)。 示例 目標(biāo) T : “Be

溫馨提示

  • 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)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論