版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
項(xiàng)目二線性表項(xiàng)目二線性表任務(wù)一:線性表的定義和基本運(yùn)算任務(wù)二:線性表的順序存儲結(jié)構(gòu)任務(wù)三:線性表的鏈?zhǔn)酱鎯Y(jié)構(gòu)線性表的邏輯結(jié)構(gòu)、存儲結(jié)構(gòu),及它們之間的相互關(guān)系;定義與之相適應(yīng)的運(yùn)算;設(shè)計相應(yīng)的算法;分析算法的效率。任務(wù)一線性表的定義和基本操作一、線性表線性表是n個數(shù)據(jù)元素的有限序列,記為:L=(a1,a2,……,an)數(shù)據(jù)元素之間的關(guān)系是:ai-1領(lǐng)先于ai
,ai領(lǐng)先于ai+1
。稱ai-1是ai的直接前驅(qū)元素;ai+1是ai的直接后繼元素。除a1外,每個元素有且僅有一個直接前驅(qū)元素;除an外,每個元素有且僅有一個直接后繼元素。線性表中數(shù)據(jù)元素的個數(shù)n(n>=0)稱為線性表的長度,當(dāng)n=0,稱為空表。任務(wù)一線性表的定義和基本操作抽象數(shù)據(jù)類型線性表的定義:ADTList{
數(shù)據(jù)對象:D={ai|ai∈ElemSet,i=1,2,……n,n>=0}{稱n為線性表的表長;
稱n=0時的線性表為空表。}
數(shù)據(jù)關(guān)系:R1={<ai-1,ai>|ai-1,ai∈D,i=2,……,n}{設(shè)線性表為(a1,a2,……,an),稱i為ai在線性表中的位序}
基本操作:{結(jié)構(gòu)初始化}
InitList(L)
操作結(jié)果:構(gòu)造一個空的線性表
{銷毀結(jié)構(gòu)}
DestroyList(L)
初始條件:線性表已存在
操作結(jié)果:構(gòu)造一個空的線性表任務(wù)一線性表的定義和基本操作抽象數(shù)據(jù)類型線性表的定義:{引用型操作}ListEmpty(L)ListLength(L)PriorElem(L,e)NextElem(L,e)GetElem(L,i)Locate(L,e)ListEmpty(L)初始條件:線性表L已存在。操作結(jié)果:若L為空表,則返回TRUE,否則FALSE。ListLength(L)初始條件:線性表L已存在。操作結(jié)果:返回L中元素的個數(shù)。PriorElem(L,e)初始條件:線性表L已存在。操作結(jié)果:若e是L的元素,但不是第一個,則返回它的前驅(qū),否則操作失敗。NextElem(L,e)初始條件:線性表L已存在。操作結(jié)果:若e是L的元素,但不是最后一個,則返回e的后繼,否則操作失敗。GetElem(L,i)初始條件:線性表L已存在,1<=i<=LengthList(L)操作結(jié)果:返回L中第i個元素的值Locate(L,e)初始條件:線性表L已存在。操作結(jié)果:返回L中e的位序。若這樣的元素不存在,則返回值0任務(wù)一線性表的定義和基本操作抽象數(shù)據(jù)類型線性表的定義:{加工型操作}ClearList(L)InsertList(L,i,e)DeleteList(L,i,e)ClearList(L)初始條件:線性表L已存在。操作結(jié)果:將L重置為空表。InsertList(L,i,e)初始條件:線性表L已存在。1<=i<=LengthList(L)+1操作結(jié)果:在L的第i個元素之前插入新的元素e,L的長度增1。DeleteList(L,i,e)初始條件:線性表L已存在。1<=i<=LengthList(L)操作結(jié)果:刪除L的第i個元素,并用e返回其值,L的長度減1。利用上述定義的線性表,可以完成其他更復(fù)雜的操作。任務(wù)一線性表的定義和基本操作例2-1求兩個集合的并集,即A=A∪B分析:設(shè)A、B分別由兩個線性表LA、LB表示,要求將LB中存在而LA中不存在的數(shù)據(jù)元素插入到表LA中任務(wù)一線性表的定義和基本操作算法描述如下(類C):voidUnion(Liner_List
LA,Liner_ListLB){LA.len=ListLength(LA);
LB.len=ListLength(LB);//求線性表的長度
for(i=1;i<=LB.len;i++){//LB中第i個元素在LA中不存在,則將其插入到LA中
if(!Locate(LA,GetElem(LB,i)))
InsertList(&LA,++LA.len,GetElem(LB,i));}}算法思想:依次從LB中取出一個元素;判斷LA中是否存在;若不存在,則插入到LA中。任務(wù)一線性表的定義和基本操作例2-2歸并兩個有序的線性表LA和LB為一個新的線性表算法思想:(1)初始化:置LC為空表,設(shè)置變量i,j,初值為1,分別指向LA和LB的第一個元素,k表示LC的長度,初值為0
。(2)當(dāng)i<=LENGTH(LA)ANDJ<=LENGTH(LB)時,判斷:若i所指的元素<=j所指的元素,則將i所指的元素插入在LC的k+1,并且i,k的值分別加1;否則,將j所指的元素插入在LC的k+1前,并且j,k的值分別加1(3)重復(fù)(2)直到某個表的元素插入完畢。(4)將未插入完的表的余下的元素,依次插入在LC后。任務(wù)一線性表的定義和基本操作算法設(shè)計如下(類C):voidMerge_List(Liner_List
LA,Liner_List
LB,Liner_ListLC){LA.len=ListLength(LA);
LB.len=ListLength(LB);//求線性表的長度
InitList(LC);//初始化線性表LC
while(i<=LA.len&&j<=LB.len)//如果LA中第i個元素小于LB中//第j個元素,把LA中第i個元素插入到LC中,否則將LB中第j個元素插入到
if(GetElem(LA,i)<=GetElem(LB,j)){InsertList(LC,k+1,GetElem(LA,i));
k++;i++;}else{InsertList(LC,k+1,GetElem(LB,j));
k++;j++;}
while(i<=LA.len){InsertList(LC,k+1,GetElem(LA,i));
k++;i++;}
while(j<=LB.len){InsertList(LC,k+1,GetElem(LB,j));
k++;j++;}}任務(wù)一線性表的定義和基本操作算法分析:該算法中包含了三個WHILE語句,其中,第一個處理了某一張表的全部元素和另一張表的部分元素;后兩個WHILE循環(huán)只可能有一個執(zhí)行,用來完成將未歸并到LC中的余下部分元素插入到LC中,“插入”是估量歸并算法時間復(fù)雜度的基本操作,其語句頻度為:
ListLength(LA)+ListLength(LB)該算法的時間復(fù)雜度為:
O(ListLength(LA)+ListLength(LB)),若LA和LB的元素個數(shù)為同數(shù)量級n,則該算法的時間復(fù)雜度為O(n)任務(wù)二線性表的順序存儲結(jié)構(gòu)一、順序存儲結(jié)構(gòu)
用一組地址連續(xù)的存儲單元依次存儲線性表的元素。設(shè)線性表的每個元素占用k個存儲單元,則第i個元素ai的存儲位置為:Loc(ai)=Loc(a1)+(i-1)*k,其中,Loc(ai)為線性表的起止線性表的順序存儲結(jié)構(gòu)是一種隨機(jī)存取的存儲結(jié)構(gòu)。
若已知線性表的起始位置(基地址)和表中每個數(shù)據(jù)元素所占存儲單元的大小k,就可以計算出線性表中任意一個數(shù)據(jù)元素的存儲地址,這種存取元素的方法稱為隨機(jī)存取法任務(wù)二線性表的順序存儲結(jié)構(gòu)任務(wù)二線性表的順序存儲結(jié)構(gòu)線性表順序存儲結(jié)構(gòu)的定義為:#defineMAXSIZE100//線性表的最大長度typedef
struct
{
ElemType
elem[MAXSIZE];//存儲線性表中數(shù)據(jù)元素的數(shù)組
intlength;//線性表的當(dāng)前長度}SeqList;typedef
struct
{
ElemType*elem;//線性表中數(shù)據(jù)元素的基地址
intlength;//線性表的當(dāng)前長度
int
listsize;//當(dāng)前為線性表分配的存儲容量}SeqList;定義一個順序表的方法有兩種:方法一:SeqListL,表示將L定義為SeqList類型的變量;方法二:SeqList*L,表示將L定義為指向SeqList類型的指針。對表中數(shù)據(jù)元素進(jìn)行操作應(yīng)使用L.elem[i]
對表中數(shù)據(jù)元素進(jìn)行操作應(yīng)使用L->elem[i]((*L).elem[i])
任務(wù)二線性表的順序存儲結(jié)構(gòu)任務(wù)二線性表的順序存儲結(jié)構(gòu)順序表的優(yōu)缺點(diǎn)優(yōu)點(diǎn):隨機(jī)存取元素、簡單直觀缺點(diǎn):插入和刪除結(jié)點(diǎn)困難、擴(kuò)展不靈活、容易造成浪費(fèi)二、順序表的基本操作1.初始化順序表2.插入數(shù)據(jù)元素3.刪除數(shù)據(jù)元素4.查找數(shù)據(jù)元素任務(wù)二線性表的順序存儲結(jié)構(gòu)任務(wù)二線性表的順序存儲結(jié)構(gòu)1、初始化順序表StatusInitList(SeqList*L){//初始化順序表
L->elem=(ElemType*)malloc(MAXSIZE*sizeof(ElemType));//分配存儲空間If(!L->elem)returnOVERFLOW;//存儲空間分配失敗L->length=0;//當(dāng)前線性表長度為0L->listsize=MAXSIZE;//初始化存儲容量returnTRUE;}算法思想:給順序表分配存儲空間,elem指針指向該順序表;判斷分配空間是否成功;設(shè)置順序表的長度為0;初始化存儲容量;任務(wù)二線性表的順序存儲結(jié)構(gòu)2、插入和刪除操作(1)插入數(shù)據(jù)元素InsertList(L,i,e)插入前:L=(a1,a2,…ai-1,ai…,an)插入后:L=(a1,a2,…ai-1,e,ai…,an)為了在順序表中第i(1≤i≤n)個位置插入數(shù)據(jù)元素e,需先將第i個至第n個元素(共n-i+1個)依次向后移動一個位置,再將e插入到第i個位置。若i=n+1,則只需在線性表的末尾插入e即可。任務(wù)二線性表的順序存儲結(jié)構(gòu)算法描述如下:StatusInsertList(SeqList*L,int
i,ElemTypee){//在順序表L中第i個位置插入數(shù)據(jù)元素e,其中1<=i<=n+1
intj;
if(i<1||i>L->length+1)
returnFALSE;//i值不合法,出錯處理
if(L->length=L.listsize)returnOVERFLOW;//當(dāng)前存儲空間滿
for(j=L->length-1;j>=i-1;j--)L->elem[j+1]=L-elem[j];//第i個位置之后的元素依次向后移L->elem[i-1]=e;//將e插入到第i個位置L->length++;//表長增1returnTRUE;}算法思想:進(jìn)行合法性檢查,1<=i<=n+1;判斷線性表是否已滿;將第n個至第i個元素逐一后移一個單元;在第i個位置處插入新元素;將表的長度加1.任務(wù)二線性表的順序存儲結(jié)構(gòu)插入算法時間復(fù)雜度分析:最壞情況是在第1個元素前插入(i=1),此時要后移n個元素,因此T(n)=O(n)任務(wù)二線性表的順序存儲結(jié)構(gòu)(2)刪除運(yùn)算DeleteList(L,i)刪除前:L=(a1,a2,…ai-1,ai,,ai+1…,an)插入后:L=(a1,a2,…ai-1,ai+1,…,an)刪除順序表中第i(1≤i≤n)個數(shù)據(jù)元素,需將第i+1個至第n個元素(共n-i個)依次向前移動一個位置。順序表進(jìn)行刪除操作的前后,其數(shù)據(jù)元素在存儲空間中的位置變化如圖2-3所示。任務(wù)二線性表的順序存儲結(jié)構(gòu)算法描述如下:StatusDeleteList(SeqList*L,inti){//在順序表L中刪除第i個數(shù)據(jù)元素e,其中1<=i<=n
intj;
if(i<1||i>L->length)
returnFALSE;//i值不合法,出錯處理
for(j=i;j<L->length;j++)L->elem[j-1]=L->elem[j];//第i個位置之后的元素依次向前移L->length--;//表長減1returnTRUE;}算法思想:進(jìn)行合法性檢查,1<=i<=n;將第i+1個至第n個元素逐一向前移一個位置;將表的長度減1.任務(wù)二線性表的順序存儲結(jié)構(gòu)刪除算法時間復(fù)雜度分析:最壞情況是刪除第1個元素,此時要前移n-1個元素,因此T(n)=O(n)任務(wù)二線性表的順序存儲結(jié)構(gòu)(3)查找運(yùn)算Locate(L,e)在順序表中查找值為e的數(shù)據(jù)元素,并返回該元素在表中的位置。方法:從第一個數(shù)據(jù)元素開始,依次將表中的元素與e進(jìn)行比較,若相等,則返回該元素在表中的位置;否則,查找失敗。任務(wù)二線性表的順序存儲結(jié)構(gòu)順序表查找算法描述如下:int
Locate(SeqList*L,ElemTypee){//在順序表L中查找值為e的數(shù)據(jù)元素查找成功,返回該元素位置,否則返回0
intj;for(j=0;j<L->length;j++)if(L->elem[j]==e)
returnj+1;return0;}算法思想:將第0個至第n-1個元素逐一與元素e比較,如值相等,返回該元素在表中位置,否則返回0;例3一個線性表L中的數(shù)據(jù)元素按升序排列,編寫一個算法,實(shí)現(xiàn)在線性表中插入一個數(shù)據(jù)元素item,使得線性表仍然保持升序排列。算法設(shè)計如下:voidInsert(SqListL,ElemTypeitem){int
溫馨提示
- 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)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)字的英語教學(xué)課程設(shè)計
- 智慧鋼琴綜合課程設(shè)計
- 白酒帶貨培訓(xùn)課程設(shè)計
- 箱包結(jié)構(gòu)課程設(shè)計
- 2025重慶市安全員考試題庫附答案
- 機(jī)械怎樣課程設(shè)計
- 煙霧傳感器的課程設(shè)計
- 禮儀 個人課程設(shè)計
- 液位測量系統(tǒng)課程設(shè)計
- 熱砂振動篩課程設(shè)計
- 輸配電線路基礎(chǔ)知識
- 低壓鑄造典型缺陷及防止
- 2015年日歷表(超清晰A4打印版)
- 剪式汽車舉升機(jī)設(shè)計
- 健康證體檢表
- 廣東省涉水建設(shè)項(xiàng)目洪水影響評價 - gd
- 市政橋梁工程施工
- 橋梁設(shè)計計算實(shí)例_橋梁課程設(shè)計1
- 長線法節(jié)段梁預(yù)制施工方案wgm
- 旅行社績效考核管理制度及考核細(xì)則含考核表
- (完整版)醫(yī)療器械軟件描述文檔.doc
評論
0/150
提交評論