




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
關(guān)于數(shù)據(jù)結(jié)構(gòu)線性表順序表第1頁(yè),此課件共48頁(yè)哦線性結(jié)構(gòu)四大特點(diǎn)第一個(gè)元素?zé)o直接前驅(qū)最后一個(gè)元素?zé)o直接后繼除第一個(gè)元素外,其他每個(gè)數(shù)據(jù)元素都有唯一一個(gè)直接前驅(qū)除最后一個(gè)元素外,其他每個(gè)數(shù)據(jù)元素都有唯一一個(gè)直接后面第2頁(yè),此課件共48頁(yè)哦線性表定義記法特點(diǎn)結(jié)構(gòu)基本術(shù)語(yǔ)空表、表長(zhǎng)直接前驅(qū)、直接后繼位序最基本、最常用的線性結(jié)構(gòu)。若n(n≥0)個(gè)數(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對(duì)1)、物理結(jié)構(gòu)(順序存儲(chǔ)和鏈?zhǔn)酱鎯?chǔ))第3頁(yè),此課件共48頁(yè)哦線性表的抽象數(shù)據(jù)類型數(shù)據(jù)對(duì)象數(shù)據(jù)關(guān)系操作集初始化、銷毀、查找、插入、刪除、求前驅(qū)(后繼)、遍歷線性表中的數(shù)據(jù)元素具有相同特性相鄰數(shù)據(jù)元素之間存在序偶關(guān)系線性表的基本操作聲明僅是模型定義,不涉及模型實(shí)現(xiàn),參數(shù)不必考慮具體數(shù)據(jù)類型,實(shí)際應(yīng)用中,具體問(wèn)題具體分析。第4頁(yè),此課件共48頁(yè)哦順序表定義特點(diǎn)C描述基本形態(tài)基本操作實(shí)現(xiàn)用一組地址連續(xù)的存儲(chǔ)單元依次存放線性表中的數(shù)據(jù)元素。采用這種存儲(chǔ)結(jié)構(gòu)的線性表叫做順序表。
a1a2
…ai-1ai
…an基地址1.數(shù)據(jù)元素在“邏輯關(guān)系上的相鄰”用“物理地址相鄰”來(lái)表示。2.順序表中任一元素都可“隨機(jī)存取”。第5頁(yè),此課件共48頁(yè)哦typedefstruct{
}SqList;//俗稱順序表#defineMAXSIZE100//線性表存儲(chǔ)空間的分配量,即數(shù)組長(zhǎng)度ElemTypeelem[MAXSIZE];int
length;//當(dāng)前長(zhǎng)度順序表的C描述第6頁(yè),此課件共48頁(yè)哦順序表空:條件L.length==0
不允許刪除操作順序表滿:條件L.length==MAXSIZE
不允許插入操作不空也不滿:可以插入,刪除操作順序表的基本形態(tài)第7頁(yè),此課件共48頁(yè)哦順序表----基本算法根據(jù)順序表的實(shí)現(xiàn)形式,表長(zhǎng)length是類型定義的屬性,可以實(shí)現(xiàn)求表長(zhǎng)、初始化、取值、判空等操作,時(shí)間復(fù)雜度均為O(1)。而遍歷算法、查找表中元素的存在、插入、刪除等操作,時(shí)間復(fù)雜度均為O(n)。第8頁(yè),此課件共48頁(yè)哦(1)初始化空表時(shí)間復(fù)雜為:O(1)順序表----基本算法L.length=0;第9頁(yè),此課件共48頁(yè)哦(2)判空時(shí)間復(fù)雜為:O(1)順序表----基本算法if(L.length==0) returnOK;else returnERROR;第10頁(yè),此課件共48頁(yè)哦(3)求表長(zhǎng)時(shí)間復(fù)雜為:O(1)順序表----基本算法 returnL.length;第11頁(yè),此課件共48頁(yè)哦(4)取元素(取第i個(gè)元素e)時(shí)間復(fù)雜為:O(1)順序表----基本算法e=L.elem[i-1];i合法if(i>=1&&i<=L.length){ e=L.elem[i-1]; returnOK;}else{ returnERROR;}第12頁(yè),此課件共48頁(yè)哦順序表----基本算法(5)遍歷for(i=1;i<=L.length;i++)visit(L.elem[i-1]);時(shí)間復(fù)雜為:O(L.length)第13頁(yè),此課件共48頁(yè)哦順序表----基本算法(6)查找搜索順序表中是否存在指定的數(shù)據(jù)元素。存在,查找成功;否則,查找失敗。第14頁(yè),此課件共48頁(yè)哦例如:順序表23754138546217L.elem[0]L.length-1e=38i12341850可見(jiàn),基本操作是:將順序表中的元素逐個(gè)和給定值e相比較。第15頁(yè),此課件共48頁(yè)哦算法的時(shí)間復(fù)雜度為:
O(L.length)intLocateElem(SqListL,Elemtypee){ for(i=1;i<=L.length;i++){ if(e==L.elem[i-1]){ returni; } } return0;}第16頁(yè),此課件共48頁(yè)哦順序表----基本算法(7)插入在順序表中插入指定的數(shù)據(jù)元素,插入成功,表長(zhǎng)增1。第17頁(yè),此課件共48頁(yè)哦線性表操作
ListInsert(&L,i,e)的實(shí)現(xiàn):首先分析:插入元素時(shí),線性表的邏輯結(jié)構(gòu)發(fā)生什么變化?第18頁(yè),此課件共48頁(yè)哦
(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>表的長(zhǎng)度增加第19頁(yè),此課件共48頁(yè)哦必備條件:表存在且不滿i值的合法性檢查:1~L.length+1將第i個(gè)到最后1個(gè)元素依次后移一個(gè)位置;在i個(gè)位置插入元素;表長(zhǎng)增加1。分析:第20頁(yè),此課件共48頁(yè)哦2118307542568721183075例如:ListInsert_Sq(L,5,66)
L.length-1087564266第21頁(yè),此課件共48頁(yè)哦O(L.length)算法的時(shí)間復(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++;//表長(zhǎng)增1 returnOK;//插入成功
}else{ returnERROR;}}第22頁(yè),此課件共48頁(yè)哦插入算法時(shí)間復(fù)雜度分析:考慮移動(dòng)元素的平均情況插入位置需要移動(dòng)的結(jié)點(diǎn)次數(shù)1n2n-1……n1n+10平均次數(shù):(1+2+…+n-1+n)/(n+1)=n/2T(n)=O(n)第23頁(yè),此課件共48頁(yè)哦順序表----基本算法(8)刪除在順序表中刪除指定位置的數(shù)據(jù)元素,刪除成功,表長(zhǎng)減1。第24頁(yè),此課件共48頁(yè)哦線性表操作
ListDelete(&L,i,&e)的實(shí)現(xiàn):首先分析:刪除元素時(shí),線性表的邏輯結(jié)構(gòu)發(fā)生什么變化?第25頁(yè),此課件共48頁(yè)哦
(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>表的長(zhǎng)度減少a1a2
…ai-1ai
ai+1
…ana1a2
…ai-1
第26頁(yè),此課件共48頁(yè)哦必備條件:表非空i值的合法性檢查:1~L.length取出第i個(gè)元素;第i個(gè)元素以后的元素向前移動(dòng)一個(gè)位置;表長(zhǎng)減小1。分析:第27頁(yè),此課件共48頁(yè)哦2118307542568721183075L.length-10pppq8756例如:ListDelete_Sq(L,5,e)
p第28頁(yè),此課件共48頁(yè)哦算法時(shí)間復(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--;//表長(zhǎng)減1 returnOK;//刪除成功
}else{ returnERROR;}}第29頁(yè),此課件共48頁(yè)哦
刪除算法時(shí)間復(fù)雜度分析:考慮移動(dòng)元素的平均情況刪除位置需要移動(dòng)的結(jié)點(diǎn)次數(shù)1n-12n-2……n0平均次數(shù):(0+1+…+n-11)/n=(n-1)/2T(n)=O(n)第30頁(yè),此課件共48頁(yè)哦時(shí)間復(fù)雜度為O(1)順序表----基本算法(9)求前驅(qū)pre=L.elem[i-2];在順序表中查找元素cur_e,位序?yàn)閕i=LocateElem(L,cur_e);cur_e是順序表中元素,但不是第一個(gè)元素便有直接前驅(qū)pre第31頁(yè),此課件共48頁(yè)哦
順序表----基本算法(10)求后繼next=L.elem[i];在順序表中查找元素cur_e,位序?yàn)閕i=LocateElem(L,cur_e);cur_e是順序表中元素,但不是最后一個(gè)元素便有直接后繼next時(shí)間復(fù)雜度為O(1)第32頁(yè),此課件共48頁(yè)哦順序表----經(jīng)典算法分析算法插入刪除基本操作移動(dòng)元素移動(dòng)元素平均移動(dòng)次數(shù)時(shí)間復(fù)雜度O(n)O(n)最好情況在n+1處插入,不需移動(dòng)刪除第n個(gè),不需移動(dòng)第33頁(yè),此課件共48頁(yè)哦線性表應(yīng)用舉例例1:合并線性表例2:歸并線性表第34頁(yè),此課件共48頁(yè)哦例1:合并線性表假設(shè)有兩個(gè)集合A和B分別用兩個(gè)線性表LA和LB表示,即:線性表中的數(shù)據(jù)元素即為集合中的成員?,F(xiàn)要求一個(gè)新的集合A=A∪B?!サ糁貜?fù)元素第35頁(yè),此課件共48頁(yè)哦擴(kuò)大線性表LA,將存在于線性表LB中而不存在于線性表LA中的數(shù)據(jù)元素插入到線性表LA中去。問(wèn)題分析:第36頁(yè),此課件共48頁(yè)哦1.從線性表LB中依次取得每個(gè)數(shù)據(jù)元素;2.依值在線性表LA中進(jìn)行查訪;3.若不存在,則插入之。GetElem(LB,i)→e
LocateElem(LA,e,equal())
ListInsert(LA,n+1,e)操作步驟:第37頁(yè),此課件共48頁(yè)哦
GetElem(Lb,i,e);//取Lb中第i個(gè)數(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);//求線性表的長(zhǎng)度
Lb_len=ListLength(Lb);for(i=1;i<=Lb_len;i++){}}//union第38頁(yè),此課件共48頁(yè)哦算法分析時(shí)間復(fù)雜度:
O(ListLength(LA)*ListLength(LB))空間復(fù)雜度:
O(1)第39頁(yè),此課件共48頁(yè)哦例2:歸并線性表已知線性表LA和LB中的數(shù)據(jù)元素按值非遞減有序排列,現(xiàn)要求將LA和LB歸并為一個(gè)新的線性表LC,且LC中的數(shù)據(jù)元素仍按值非遞減有序排列。——不去掉重復(fù)元素第40頁(yè),此課件共48頁(yè)哦LC中的數(shù)據(jù)元素或是LA中的數(shù)據(jù)元素,或是LB中的數(shù)據(jù)元素。則先設(shè)LC為空表,然后將LA或LB中的元素逐個(gè)插入到LC中。為使LC表按值非遞減有序排列,可設(shè)兩個(gè)整型變量i、j,分別指向LA和LB,比較i、j所指元素的大小,決定哪個(gè)元素插入LC。插入后,在LA或LB中順序后移。問(wèn)題分析:第41頁(yè),此課件共48頁(yè)哦voidMergeList(ListLa,ListLb,List&Lc){
//本算法將非遞減的有序表La和Lb歸并為L(zhǎng)c}//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);第42頁(yè),此課件共48頁(yè)哦GetElem(La,i,ai);GetElem(Lb,j,bj);if(ai<=bj){ListInsert(Lc,++k,ai);++i;}else{ListInsert(Lc,++k,bj);++j;}
第43頁(yè),此課件共48頁(yè)哦
while(i<=La_len){//當(dāng)La不空時(shí)
GetElem(La,i++,ai);ListInsert(Lc,++k,ai);
}
//插入La表中剩余元素
while(j<=Lb_len){//當(dāng)Lb不空時(shí)
GetElem(Lb,j++,bj);ListInsert(Lc,++k,bj);
}
//插入Lb表中剩余元素第44頁(yè),此課件共48頁(yè)哦算法分析時(shí)間復(fù)雜度:O(ListLength(LA)+ListLength(LB))
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝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ù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年菏澤市定陶區(qū)公開招聘教師(44人)模擬試卷及答案詳解一套
- 2025北京石景山區(qū)招聘社區(qū)工作者模擬試卷參考答案詳解
- 2025湖北宜昌市點(diǎn)軍區(qū)招聘社區(qū)專職人員(網(wǎng)格員)6人考前自測(cè)高頻考點(diǎn)模擬試題及答案詳解(有一套)
- 2025年公安交警考試試題及答案
- 選區(qū)激光熔化Al-Ce-Sc-Zr耐熱共晶鋁合金的微觀組織及強(qiáng)韌化機(jī)理研究
- 2025福建南平市山點(diǎn)水園林有限公司招聘及擬進(jìn)入考前自測(cè)高頻考點(diǎn)模擬試題及答案詳解(考點(diǎn)梳理)
- 2025廣東東莞市水務(wù)局招聘聘用人員2人考前自測(cè)高頻考點(diǎn)模擬試題及完整答案詳解1套
- 公司保健按摩師上崗考核試卷及答案
- 戶外安全知識(shí)培訓(xùn)方案課件
- 2025北京清華附中上莊學(xué)校招聘模擬試卷及1套參考答案詳解
- 物流配送調(diào)度管理系統(tǒng)設(shè)計(jì)方案
- 35kV線路工程電桿安裝施工方案
- 2025年鄉(xiāng)鎮(zhèn)工會(huì)集體協(xié)商指導(dǎo)員招聘考試試題庫(kù)及答案
- 2025-2026學(xué)年蘇教版(2024)小學(xué)科學(xué)二年級(jí)上冊(cè)教學(xué)計(jì)劃及進(jìn)度表
- 2025年度環(huán)評(píng)文件技術(shù)復(fù)核服務(wù)方案投標(biāo)文件(技術(shù)方案)
- 新生兒硬腫癥個(gè)案護(hù)理
- 2025至2030中國(guó)生物醫(yī)藥行業(yè)發(fā)展趨勢(shì)分析與未來(lái)投資戰(zhàn)略咨詢研究報(bào)告
- 城市智能感知系統(tǒng)-洞察及研究
- 藝考機(jī)構(gòu)學(xué)校合作協(xié)議書
- 2025至2030全球及中國(guó)汽油汽車噴油器行業(yè)項(xiàng)目調(diào)研及市場(chǎng)前景預(yù)測(cè)評(píng)估報(bào)告
- 肺結(jié)核患兒的護(hù)理
評(píng)論
0/150
提交評(píng)論