版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
第二章線性表——順序表1線性結(jié)構(gòu)四大特點第一個元素?zé)o直接前驅(qū)最后一個元素?zé)o直接后繼除第一個元素外,其他每個數(shù)據(jù)元素都有唯一一個直接前驅(qū)除最后一個元素外,其他每個數(shù)據(jù)元素都有唯一一個直接后面2線性表定義記法特點結(jié)構(gòu)基本術(shù)語空表、表長直接前驅(qū)、直接后繼位序最基本、最常用的線性結(jié)構(gòu)。若n(n≥0)個數(shù)據(jù)特性相同的數(shù)據(jù)元素組成的有限序列。(a1,a2,…,ai-1,ai,ai+1,…,an)1.同一線性表中的數(shù)據(jù)元素必須具有相同特性2.具有線性結(jié)構(gòu)的四大特性3.數(shù)據(jù)元素之間存在序偶關(guān)系邏輯結(jié)構(gòu)(1對1)、物理結(jié)構(gòu)(順序存儲和鏈?zhǔn)酱鎯Γ?線性表的抽象數(shù)據(jù)類型數(shù)據(jù)對象數(shù)據(jù)關(guān)系操作集初始化、銷毀、查找、插入、刪除、求前驅(qū)(后繼)、遍歷線性表中的數(shù)據(jù)元素具有相同特性相鄰數(shù)據(jù)元素之間存在序偶關(guān)系線性表的基本操作聲明僅是模型定義,不涉及模型實現(xiàn),參數(shù)不必考慮具體數(shù)據(jù)類型,實際應(yīng)用中,具體問題具體分析。4順序表定義特點C描述基本形態(tài)基本操作實現(xiàn)用一組地址連續(xù)的存儲單元依次存放線性表中的數(shù)據(jù)元素。采用這種存儲結(jié)構(gòu)的線性表叫做順序表。
a1a2
…ai-1ai
…an基地址1.數(shù)據(jù)元素在“邏輯關(guān)系上的相鄰”用“物理地址相鄰”來表示。2.順序表中任一元素都可“隨機存取”。5typedefstruct{
}SqList;//俗稱順序表#defineMAXSIZE100//線性表存儲空間的分配量,即數(shù)組長度ElemTypeelem[MAXSIZE];int
length;//當(dāng)前長度順序表的C描述6順序表空:條件L.length==0
不允許刪除操作順序表滿:條件L.length==MAXSIZE
不允許插入操作不空也不滿:可以插入,刪除操作順序表的基本形態(tài)7順序表----基本算法根據(jù)順序表的實現(xiàn)形式,表長length是類型定義的屬性,可以實現(xiàn)求表長、初始化、取值、判空等操作,時間復(fù)雜度均為O(1)。而遍歷算法、查找表中元素的存在、插入、刪除等操作,時間復(fù)雜度均為O(n)。8(1)初始化空表時間復(fù)雜為:O(1)順序表----基本算法L.length=0;9(2)判空時間復(fù)雜為:O(1)順序表----基本算法if(L.length==0) returnOK;else returnERROR;10(3)求表長時間復(fù)雜為:O(1)順序表----基本算法 returnL.length;11(4)取元素(取第i個元素e)時間復(fù)雜為:O(1)順序表----基本算法e=L.elem[i-1];i合法if(i>=1&&i<=L.length){ e=L.elem[i-1]; returnOK;}else{ returnERROR;}12順序表----基本算法(5)遍歷for(i=1;i<=L.length;i++)visit(L.elem[i-1]);時間復(fù)雜為:O(L.length)13順序表----基本算法(6)查找搜索順序表中是否存在指定的數(shù)據(jù)元素。存在,查找成功;否則,查找失敗。14例如:順序表23754138546217L.elem[0]L.length-1e=38i12341850可見,基本操作是:將順序表中的元素逐個和給定值e相比較。15算法的時間復(fù)雜度為:
O(L.length)intLocateElem(SqListL,Elemtypee){ for(i=1;i<=L.length;i++){ if(e==L.elem[i-1]){ returni; } } return0;}16順序表----基本算法(7)插入在順序表中插入指定的數(shù)據(jù)元素,插入成功,表長增1。17線性表操作
ListInsert(&L,i,e)的實現(xiàn):首先分析:插入元素時,線性表的邏輯結(jié)構(gòu)發(fā)生什么變化?18
(a1,…,ai-1,ai,…,an)改變?yōu)?/p>
(a1,…,ai-1,e,ai,…,an)a1a2
…ai-1ai
…ana1a2
…ai-1
…aiean<ai-1,ai><ai-1,e>,<e,ai>表的長度增加19必備條件:表存在且不滿i值的合法性檢查:1~L.length+1將第i個到最后1個元素依次后移一個位置;在i個位置插入元素;表長增加1。分析:202118307542568721183075例如:ListInsert_Sq(L,5,66)
L.length-108756426621O(L.length)算法的時間復(fù)雜度為:StatusListInsert(SqList&L,inti,ElemTypee){if(i>=1&&i<=L.length+1){ for(j=L.length;j>=i;j--)//元素后移
L.elem[j]=L.elem[j-1]; L.elem[i-1]=e;//插入e L.length++;//表長增1 returnOK;//插入成功
}else{ returnERROR;}}22插入算法時間復(fù)雜度分析:考慮移動元素的平均情況插入位置需要移動的結(jié)點次數(shù)1n2n-1……n1n+10平均次數(shù):(1+2+…+n-1+n)/(n+1)=n/2T(n)=O(n)23順序表----基本算法(8)刪除在順序表中刪除指定位置的數(shù)據(jù)元素,刪除成功,表長減1。24線性表操作
ListDelete(&L,i,&e)的實現(xiàn):首先分析:刪除元素時,線性表的邏輯結(jié)構(gòu)發(fā)生什么變化?25
(a1,…,ai-1,ai,ai+1,…,an)改變?yōu)?/p>
(a1,…,ai-1,ai+1,…,an)ai+1…an<ai-1,ai>,<ai,ai+1><ai-1,ai+1>表的長度減少a1a2
…ai-1ai
ai+1
…ana1a2
…ai-1
26必備條件:表非空i值的合法性檢查:1~L.length取出第i個元素;第i個元素以后的元素向前移動一個位置;表長減小1。分析:272118307542568721183075L.length-10pppq8756例如:ListDelete_Sq(L,5,e)
p28算法時間復(fù)雜度為:
O(L.length)StatusListDelete(SqList&L,inti,ElemType&e){if(i>=1&&i<=L.length){ e=L.elem[i-1]; for(j=i+1;j<=L.length;j++)//元素前移
L.elem[j-2]=L.elem[j-1]; L.length--;//表長減1 returnOK;//刪除成功
}else{ returnERROR;}}29
刪除算法時間復(fù)雜度分析:考慮移動元素的平均情況刪除位置需要移動的結(jié)點次數(shù)1n-12n-2……n0平均次數(shù):(0+1+…+n-11)/n=(n-1)/2T(n)=O(n)30時間復(fù)雜度為O(1)順序表----基本算法(9)求前驅(qū)pre=L.elem[i-2];在順序表中查找元素cur_e,位序為ii=LocateElem(L,cur_e);cur_e是順序表中元素,但不是第一個元素便有直接前驅(qū)pre31
順序表----基本算法(10)求后繼next=L.elem[i];在順序表中查找元素cur_e,位序為ii=LocateElem(L,cur_e);cur_e是順序表中元素,但不是最后一個元素便有直接后繼next時間復(fù)雜度為O(1)32順序表----經(jīng)典算法分析算法插入刪除基本操作移動元素移動元素平均移動次數(shù)時間復(fù)雜度O(n)O(n)最好情況在n+1處插入,不需移動刪除第n個,不需移動33線性表應(yīng)用舉例例1:合并線性表例2:歸并線性表34例1:合并線性表假設(shè)有兩個集合A和B分別用兩個線性表LA和LB表示,即:線性表中的數(shù)據(jù)元素即為集合中的成員。現(xiàn)要求一個新的集合A=A∪B?!サ糁貜?fù)元素35擴大線性表LA,將存在于線性表LB中而不存在于線性表LA中的數(shù)據(jù)元素插入到線性表LA中去。問題分析:361.從線性表LB中依次取得每個數(shù)據(jù)元素;2.依值在線性表LA中進行查訪;3.若不存在,則插入之。GetElem(LB,i)→e
LocateElem(LA,e,equal())
ListInsert(LA,n+1,e)操作步驟:37
GetElem(Lb,i,e);//取Lb中第i個數(shù)據(jù)元素賦給e
if(!LocateElem(La,e,equal()))
ListInsert(La,++La_len,e);
//La中不存在和e相同的數(shù)據(jù)元素,則插入之voidunion(List&La,ListLb){La_len=ListLength(La);//求線性表的長度
Lb_len=ListLength(Lb);for(i=1;i<=Lb_len;i++){}}//union38算法分析時間復(fù)雜度:
O(ListLength(LA)*ListLength(LB))空間復(fù)雜度:
O(1)39例2:歸并線性表已知線性表LA和LB中的數(shù)據(jù)元素按值非遞減有序排列,現(xiàn)要求將LA和LB歸并為一個新的線性表LC,且LC中的數(shù)據(jù)元素仍按值非遞減有序排列。——不去掉重復(fù)元素40LC中的數(shù)據(jù)元素或是LA中的數(shù)據(jù)元素,或是LB中的數(shù)據(jù)元素。則先設(shè)LC為空表,然后將LA或LB中的元素逐個插入到LC中。為使LC表按值非遞減有序排列,可設(shè)兩個整型變量i、j,分別指向LA和LB,比較i、j所指元素的大小,決定哪個元素插入LC。插入后,在LA或LB中順序后移。問題分析:41voidMergeList(ListLa,ListLb,List&Lc){
//本算法將非遞減的有序表La和Lb歸并為Lc}//merge_listwhile((i<=La_len)&&(j<=Lb_len))
{……//La和Lb均不空
}while(i<=La_len)
//若La不空while(j<=Lb_len)//若Lb不空InitList(Lc);//構(gòu)造空的線性表Lci=j=1;k=0;La_len=ListLength(La);Lb_len=ListLength(Lb);42GetElem(La,i,ai);GetElem(Lb,j,bj);if(ai<=bj){ListInsert(Lc,++k,ai);++i;}else{ListInsert(Lc,++k,bj);++j;}
43
while(i<=La_len){//當(dāng)La不空時
GetElem(La,i++,ai);ListInsert(Lc,++k,ai);
}
//插入La表中剩余元素
while(j<=Lb_len){//當(dāng)Lb不空時
GetElem(Lb,j++,bj);ListInsert(Lc,++k,bj);
}
//插入Lb表中剩余元素44算法分析時間復(fù)雜度:O(ListLength(LA)+ListLength(LB))空間復(fù)雜度:O(ListLength(LA)+ListLength(LB))45voidMergeList(SqListLa,SqListLb,SqList&Lc){ pa=La.elem;pb=Lb.elem; Lc.lengt
溫馨提示
- 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)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 精2024年度智能家居系統(tǒng)安裝合同
- 二零二五年度互聯(lián)網(wǎng)數(shù)據(jù)中心(IDC)租賃合同4篇
- 2025版生態(tài)園林景觀設(shè)計施工一體化合同4篇
- 二零二五年房地產(chǎn)養(yǎng)老地產(chǎn)合作開發(fā)合同3篇
- 二零二五年度高檔酒店餐飲合作租賃合同范本2篇
- 二零二五年食品加工企業(yè)冷鏈配送采購代理合同5篇
- 二零二五年電商平臺網(wǎng)絡(luò)安全保密與應(yīng)急響應(yīng)合同2篇
- 2025版路燈照明設(shè)備租賃與節(jié)能改造及維護服務(wù)合同4篇
- 專業(yè)地磚鋪貼及售后服務(wù)合同版B版
- 二零二四南海實驗學(xué)校校園物業(yè)服務(wù)與信息化建設(shè)合同2篇
- 2025年工程合作協(xié)議書
- 2025年山東省東營市東營區(qū)融媒體中心招聘全媒體采編播專業(yè)技術(shù)人員10人歷年高頻重點提升(共500題)附帶答案詳解
- 2025年宜賓人才限公司招聘高頻重點提升(共500題)附帶答案詳解
- KAT1-2023井下探放水技術(shù)規(guī)范
- 駕駛證學(xué)法減分(學(xué)法免分)題庫及答案200題完整版
- 竣工驗收程序流程圖
- 清華經(jīng)管工商管理碩士研究生培養(yǎng)計劃
- 口腔科診斷證明書模板
- 管溝挖槽土方計算公式
- 國網(wǎng)浙江省電力公司住宅工程配電設(shè)計技術(shù)規(guī)定
- 煙花爆竹零售應(yīng)急預(yù)案
評論
0/150
提交評論