




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第2章線性表2.1線性表的邏輯結(jié)構(gòu)2.2線性表的順序表示和實(shí)現(xiàn)2.3線性表的鏈?zhǔn)奖硎竞蛯?shí)現(xiàn)2.4應(yīng)用舉例1例1:兩個(gè)鏈表的歸并(教材P31例)例2:一元多項(xiàng)式的計(jì)算
(教材P39–43)例3:試用C或類C語(yǔ)言編寫一個(gè)高效算法,將一循環(huán)單鏈表就地逆置。
微軟亞洲研究院去年來校招聘的筆試題操作前:(a1,a2,…ai-1,ai,ai+1,…,an)操作后:(an,…ai+1
,ai,ai-1,…,a2,a1)2分析:要想讓an指向an-1,……a2指向a1,一般有兩種算法:①替換法:掃描a1……an,將每個(gè)ai-1的指針域送入ai+1的指針域。實(shí)際上是鏈棧的概念操作后:(an,…ai+1
,ai,ai-1,…,a2,a1)^a1heada2思路:后繼變前驅(qū)思路:頭部變尾部②插入法:掃描a1……an,將每個(gè)ai插入到鏈表首部即可。3就地逆置程序段的改進(jìn)(周小明課后提交)//主程序被降到8行,因?yàn)閷?duì)空表的檢測(cè)可以不要。q=head->Next;//有頭結(jié)點(diǎn)pCur=q->Next;q->Next=(List*)head;
//第一結(jié)點(diǎn)處理while(pCur!=(List*)head)//空表或只有一個(gè)結(jié)點(diǎn)均會(huì)跳過{ q=pCur->Next;//保存原后繼 pCur->Next=head->Next; head->Next=pCur; pCur=q;}5例4:試用C或類C語(yǔ)言編寫一高效算法,將一順序存儲(chǔ)的線性表(設(shè)元素均為整型量)中所有零元素向表尾集中,其他元素則順序向表頭方向集中。深圳華為公司去年來校招聘面試題常見做法:①?gòu)那巴髵呙?,見?元素則與尾部非0元素互換;②從后往前掃描,見到0元素則后面元素統(tǒng)統(tǒng)前移;③從前往后掃描,見到0元素先計(jì)數(shù),再將后續(xù)的一個(gè)非0元素前移,全部掃完后再把后續(xù)部分(長(zhǎng)度為0元素的個(gè)數(shù))清0。××√(a1,a2,…ai-1,ai,ai+1,…,an)6解:voidSortA(sqlist&L){inti=0,zerosum=0;if(L.length==0)return(0);//空表則結(jié)束else{for(i=1;i<=L.length;i++){if(L.v[i]<>0)L.v[i-zerosum]=L.v[i];elsezerosum++;}}for(i=L.length-zerosum+1;i<=L.length;i++)L.v[i]=0;//表的后部補(bǔ)0return(ok);}//SortA若表完全不空,也要移動(dòng)n次?7解:
voidSortA(sqlist&L){inti=0,zerosum=0;if(L.length==0)return(0);
//空表則不執(zhí)行for(i;i<=L.length;i++){if(L.v[i]<>0&zerosum!=0)L.v[i-zerosum]=L.v[i];elsezerosum++};//適當(dāng)移動(dòng)非零元素,是零則增加計(jì)數(shù)for(i=L.length-zerosum+1;i<=L.length;i++)L.v[i]=0;//表的后部補(bǔ)0return(ok);}若考慮表完全非空的情況,則程序要變長(zhǎng)很多。8動(dòng)態(tài)鏈表樣式:靜態(tài)鏈表樣式:指針數(shù)據(jù)指針數(shù)據(jù)指針數(shù)據(jù)指示數(shù)據(jù)指示數(shù)據(jù)指示數(shù)據(jù)指示數(shù)據(jù)指示數(shù)據(jù)數(shù)組中每個(gè)元素都至少有兩個(gè)分量,屬于結(jié)構(gòu)型數(shù)組。常用于無指針類型的高級(jí)語(yǔ)言中。10前例2:一線性表S=(ZHAO,QIAN,SUN,LI,ZHOU,WU),用靜態(tài)鏈表如何表示?——教材P32例題data0123456…1000cur說明1:假設(shè)S為SLinkList型變量,則S[MAXSIZE]為一個(gè)靜態(tài)鏈表;S[0].cur則表示第1個(gè)結(jié)點(diǎn)在數(shù)組中的位置。說明2:如果數(shù)組的第i個(gè)分量表示鏈表的第k個(gè)結(jié)點(diǎn),則:S[i].data表示第k個(gè)結(jié)點(diǎn)的數(shù)據(jù);S[i].cur表示第k+1個(gè)結(jié)點(diǎn)(即k的直接后繼)的位置。i頭結(jié)點(diǎn)12例6:在雙向鏈表中如何實(shí)現(xiàn)插入和刪除運(yùn)算?單鏈表中查找只能從前往后,而不能從后往前查。為了查找方便,提高查找速度,可以在結(jié)點(diǎn)上增加一個(gè)指針域,用來存結(jié)點(diǎn)的直接前驅(qū),這樣的鏈表,稱為雙向鏈表。其結(jié)點(diǎn)的結(jié)構(gòu)為:typedefstructDuLNode{
ElemTypedata;//數(shù)據(jù)域
structDuLNode*prior;
//前驅(qū)指針域structDuLNode*next;//后繼指針域}DuLNode,*DuLinkList;
雙向鏈表類型的定義如下:14雙向鏈表的插入操作:設(shè)p已指向第i元素,請(qǐng)?jiān)诘趇元素前插入元素x①ai-1的后繼從ai(指針是p)變?yōu)閤(指針是s):s->next=p;
p->prior->next=s;
②ai的前驅(qū)從ai-1(指針是p->prior)變?yōu)閤(指針是s);s->prior=p->prior;p->prior=s;
注意:要修改雙向指針!x
sai-1
ai
p指針域的變化:15指針域的變化:后繼方向:ai-1的后繼由ai(指針p)變?yōu)閍i+1(指針p->next
);
p->prior->next
=
p->next;前驅(qū)方向:ai+1的前驅(qū)由ai(指針p)變?yōu)閍i-1(指針p->prior
);
p->next->prior
=p->prior;
ai-1
ai+1
ai
p雙向鏈表的刪除操作:設(shè)p指向第i個(gè)元素,刪除第i個(gè)元素注意:要修改雙向指針!16本章小結(jié)線性結(jié)構(gòu)(包括表、棧、隊(duì)、數(shù)組)的定義和特點(diǎn):僅一個(gè)首、尾結(jié)點(diǎn),其余元素僅一個(gè)直接前驅(qū)和一個(gè)直接后繼。2.線性表邏輯結(jié)構(gòu):“一對(duì)一”或“1:1”存儲(chǔ)結(jié)構(gòu):順序、鏈?zhǔn)竭\(yùn)算:修改、插入、刪除[查找和排序另述]3.順序存儲(chǔ)特征:邏輯上相鄰,物理上也相鄰;優(yōu)點(diǎn):隨機(jī)查找修改快
O(1)缺點(diǎn):插入、刪除慢O(n)改進(jìn)方案:鏈表存儲(chǔ)結(jié)構(gòu)17循環(huán)鏈表的特點(diǎn):從任一結(jié)點(diǎn)出發(fā)均可找到表中其他結(jié)點(diǎn)雙向鏈表的特點(diǎn):可方便找到任一結(jié)點(diǎn)的前驅(qū)靜態(tài)鏈表的特點(diǎn):不用指針也能實(shí)現(xiàn)鏈?zhǔn)酱鎯?chǔ)和運(yùn)算4.鏈?zhǔn)酱鎯?chǔ)特征:邏輯上相鄰,物理上未必相鄰;優(yōu)點(diǎn):插入、刪除快
O(1)缺點(diǎn):隨機(jī)查找修改慢O(n)5.幾種特殊鏈表的特點(diǎn):18討論2:什么是指針?指針的作用?指針—即變量的內(nèi)存地址。指針主要功能有二:①提供了一種快速訪問數(shù)組單元的途徑;②使C語(yǔ)言函數(shù)可以修改其調(diào)用的參數(shù)。
&---指針操作符(單目),返回操作數(shù)地址;
*---運(yùn)算符(單目),是對(duì)&的補(bǔ)充,返回位于這個(gè)地址內(nèi)的變量之值。例:q=*m意即“q取地址m中的值”。如果數(shù)值100存儲(chǔ)在內(nèi)存地址2000中,而這一地址又存在m中,則q=(2000)=100討論3:與指針有關(guān)的符號(hào)&和*之間有何區(qū)別?20P43程序中,switch(*cmp(a,b))的cmp(a,b)一定是個(gè)特殊變量,它的值是一個(gè)內(nèi)存地址,而-1,0,+1這三種可能的執(zhí)行結(jié)果會(huì)放入該地址中,所存結(jié)果再由*cmp來尋址。那么,P42定義為intcmp(a,b)又怎么理解?意即cmp中地址(指針)存儲(chǔ)的是一個(gè)整型變量討論4:
P43程序中,switch(*cmp(a,b))的意思?21編制遞歸算法要注意些什么?遞歸進(jìn)行是有條件的。一般常把判斷語(yǔ)句加在遞歸語(yǔ)句以前。遞歸的最底層應(yīng)該有返回值,以供上層遞歸的調(diào)用。否則會(huì)死循環(huán)。遞歸調(diào)用需要利用堆棧。參量的初始化應(yīng)該在遞歸以前。 每次調(diào)用要把本次調(diào)用的參數(shù)和局部變量保存在棧頂。每次從下一層調(diào)用返回到上一層調(diào)用時(shí),從棧頂恢復(fù)本層調(diào)用的參數(shù)和局部變量的值。23例2:設(shè)正整數(shù)a的前驅(qū)為PRIOR(a),后繼為NEXT(a),用遞歸算法計(jì)算a+b。
平常我們可以用循環(huán)來實(shí)現(xiàn),但根據(jù)本題題意不能用循環(huán),而要用遞歸。設(shè)計(jì)要點(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. 人人文庫(kù)網(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 教育行業(yè)勞動(dòng)合同范文
- 合作發(fā)展合同-股本借款標(biāo)準(zhǔn)范本
- 租賃合同糾紛調(diào)解協(xié)議書范本
- 10-1《蘭亭集序》教學(xué)設(shè)計(jì) 2023-2024學(xué)年統(tǒng)編版高中語(yǔ)文選擇性必修下冊(cè)
- 10 吃飯有講究 教學(xué)設(shè)計(jì)-2024-2025學(xué)年道德與法治一年級(jí)上冊(cè)統(tǒng)編版
- 長(zhǎng)期借款合同參考模板
- 貸款合同范本:全新標(biāo)準(zhǔn)版
- 環(huán)保治理工程承包合同范文
- 生產(chǎn)訂購(gòu)合同范本
- 餐飲直營(yíng)協(xié)議合同范本
- 借哪吒精神燃開學(xué)斗志 開學(xué)主題班會(huì)課件
- 學(xué)校教職工代表大會(huì)全套會(huì)議會(huì)務(wù)資料匯編
- 新部編版小學(xué)六年級(jí)下冊(cè)語(yǔ)文第二單元測(cè)試卷及答案
- 《中醫(yī)基礎(chǔ)理論》課件-中醫(yī)學(xué)理論體系的基本特點(diǎn)-整體觀念
- 2025年廣東省深圳法院招聘書記員招聘144人歷年高頻重點(diǎn)提升(共500題)附帶答案詳解
- 2025年人教版新教材數(shù)學(xué)一年級(jí)下冊(cè)教學(xué)計(jì)劃(含進(jìn)度表)
- GB/T 45107-2024表土剝離及其再利用技術(shù)要求
- 2025年春西師版一年級(jí)下冊(cè)數(shù)學(xué)教學(xué)計(jì)劃
- 一年級(jí)家長(zhǎng)會(huì)課件2024-2025學(xué)年
- 2024年海南省??谑行∩鯏?shù)學(xué)試卷(含答案)
- 廣東省五年一貫制語(yǔ)文試卷
評(píng)論
0/150
提交評(píng)論