版權(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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025塔機(jī)租賃合同(詳細(xì)版)
- 2025車位買賣合同
- 2024年高純超細(xì)氧化硅纖維項(xiàng)目資金需求報(bào)告代可行性研究報(bào)告
- 智慧醫(yī)療下的醫(yī)院食堂智能點(diǎn)餐系統(tǒng)分析
- 2024年核酸疫苗項(xiàng)目資金籌措計(jì)劃書代可行性研究報(bào)告
- 科技輔助下的小學(xué)數(shù)學(xué)自主學(xué)習(xí)能力培養(yǎng)
- 江蘇省靖江市2024-2025學(xué)年七年級上學(xué)期1月期末道德與法治試題(含答案)
- 2025年外研銜接版九年級歷史上冊階段測試試卷含答案
- 2025年華東師大版選修3物理下冊階段測試試卷含答案
- 2025年北師大新版九年級物理下冊階段測試試卷含答案
- 中醫(yī)診療方案腎病科
- 人教版(2025新版)七年級下冊數(shù)學(xué)第七章 相交線與平行線 單元測試卷(含答案)
- 完整2024年開工第一課課件
- 從跨文化交際的角度解析中西方酒文化(合集5篇)xiexiebang.com
- 中藥飲片培訓(xùn)課件
- 醫(yī)院護(hù)理培訓(xùn)課件:《早產(chǎn)兒姿勢管理與擺位》
- 《論文的寫作技巧》課件
- 空氣自動站儀器運(yùn)營維護(hù)項(xiàng)目操作說明以及簡單故障處理
- 2022年12月Python-一級等級考試真題(附答案-解析)
- T-CHSA 020-2023 上頜骨缺損手術(shù)功能修復(fù)重建的專家共識
- Hypermesh lsdyna轉(zhuǎn)動副連接課件完整版
評論
0/150
提交評論