計(jì)算機(jī)軟件技術(shù)基礎(chǔ)第2章鏈表_第1頁
計(jì)算機(jī)軟件技術(shù)基礎(chǔ)第2章鏈表_第2頁
計(jì)算機(jī)軟件技術(shù)基礎(chǔ)第2章鏈表_第3頁
計(jì)算機(jī)軟件技術(shù)基礎(chǔ)第2章鏈表_第4頁
計(jì)算機(jī)軟件技術(shù)基礎(chǔ)第2章鏈表_第5頁
已閱讀5頁,還剩20頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1單鏈表(SinglyLinkedList)循環(huán)鏈表(CircularList)多項(xiàng)式及其相加雙向鏈表(DoublyLinkedList)稀疏矩陣第二章鏈表2單鏈表特點(diǎn)

每個(gè)元素(表項(xiàng))由結(jié)點(diǎn)(Node)構(gòu)成。線性結(jié)構(gòu)

結(jié)點(diǎn)可以不連續(xù)存儲表可擴(kuò)充3單鏈表的存儲映像4單鏈表中的插入與刪除插入第一種情況:在第一個(gè)結(jié)點(diǎn)前插入

newnode→link=first;first=newnode;(插入前)(插入后)x

5(插入前)(插入后)

第二種情況:在鏈表中間插入newnode→link=p→link;

p→link=newnode;6

第三種情況:在鏈表末尾插入

newnode→link=p→link;

p→link=last=newnode;(插入前)(插入后)7voidList::Insert(constintx,constinti){//在鏈表第i個(gè)結(jié)點(diǎn)處插入新元素xNode*p=first;intk=0;while(p!=NULL&&k<i-1){p=p→link;k++;}//找第i-1個(gè)結(jié)點(diǎn)

Node*newnode=newNode(x,NULL);//創(chuàng)建新結(jié)點(diǎn)if(first==NULL||i==0){//插在表前newnode→link=first; if(first==NULL)last=newnode; first=newnode;}else{//插在表中或末尾newnode→link=p→link; if(p→link==NULL)last=newnode;p→link=newnode;}}8刪除第一種情況:刪除表中第一個(gè)元素第二種情況:刪除表中或表尾元素在單鏈表中刪除含ai的結(jié)點(diǎn)9帶表頭結(jié)點(diǎn)的單鏈表表頭結(jié)點(diǎn)位于表的最前端,本身不帶數(shù)據(jù),僅標(biāo)志表頭。設(shè)置表頭結(jié)點(diǎn)的目的是統(tǒng)一空表與非空表的操作,簡化鏈表操作的實(shí)現(xiàn)。非空表 空表10在帶表頭結(jié)點(diǎn)的單鏈表:插入新結(jié)點(diǎn)

newnode→link=p→link; if(p→link==NULL)last=newnode;p→link=newnode;11

q=p→link;p→link=q→link;deleteq;if(p→link==NULL)last=p;從帶表頭結(jié)點(diǎn)的單鏈表中刪除一個(gè)結(jié)點(diǎn)12靜態(tài)鏈表結(jié)構(gòu):利用數(shù)組定義,運(yùn)算過程中存儲空間大小不變13循環(huán)鏈表(CircularList)循環(huán)鏈表是單鏈表的變形。循環(huán)鏈表最后一個(gè)結(jié)點(diǎn)的link指針不為0(NULL),而是指向了表的前端。為簡化操作,在循環(huán)鏈表中往往加入表頭結(jié)點(diǎn)。循環(huán)鏈表的特點(diǎn)是:只要知道表中某一結(jié)點(diǎn)的地址,就可搜尋到所有其他結(jié)點(diǎn)的地址。14循環(huán)鏈表的示例帶表頭結(jié)點(diǎn)的循環(huán)鏈表

15用循環(huán)鏈表求解約瑟夫問題約瑟夫問題的提法

n個(gè)人圍成一個(gè)圓圈,首先從1開始一個(gè)人一個(gè)人順時(shí)針報(bào)數(shù),報(bào)到第m個(gè)人,令其出列。然后再從下一個(gè)人開始,從1順時(shí)針報(bào)數(shù),報(bào)到第m個(gè)人,再令其出列,…,如此下去,直到圓圈中只剩一個(gè)人為止。此人即為優(yōu)勝者。例如n=8m=31617約瑟夫問題的解法voidJosephus(int

n,intm){

for(int

i=0;

i<n-1;

i++){

//執(zhí)行n-1次

for(int

j=0;

j<m-1;

j++)Next();

cout<<“Deleteperson”<<

getData()<<endl;//數(shù)m-1個(gè)人

Remove();//刪去}}18多項(xiàng)式及其相加在多項(xiàng)式的鏈表表示中每個(gè)結(jié)點(diǎn)增加了一個(gè)數(shù)據(jù)成員link,作為鏈接指針。優(yōu)點(diǎn)是:多項(xiàng)式的項(xiàng)數(shù)可以動態(tài)地增長,不存在存儲溢出問題。插入、刪除方便,不移動元素。19多項(xiàng)式(polynomial)類的鏈表定義struct

Term{

intcoef;

intexp;

void

Init(int

c,

int

e){coef=c;exp=e;

}};

20多項(xiàng)式鏈表的相加AH=1-10x6+2x8+7x14BH=-x4+10x6-3x10+8x14+4x1821雙向鏈表(DoublyLinkedList)雙向鏈表是指在前驅(qū)和后繼方向都能游歷(遍歷)的線性鏈表。雙向鏈表每個(gè)結(jié)點(diǎn)結(jié)構(gòu):

前驅(qū)方向

后繼方向雙向鏈表通常采用帶表頭結(jié)點(diǎn)的循環(huán)鏈表形式。22結(jié)點(diǎn)指向

p==

p→lLink→rLink==p→rLink→lLink非空表 空表23搜索成功搜索不成功雙向循環(huán)鏈表的搜索算法24p→lLink=current; p→rLink=current→rLink; current→rLink=p;current=current→rLink;

溫馨提示

  • 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

提交評論