線性表是一種最簡(jiǎn)單的線性結(jié)構(gòu)_第1頁(yè)
已閱讀1頁(yè),還剩94頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、1,線性表是一種最簡(jiǎn)單的線性結(jié)構(gòu),第二章 線性表,2,線性結(jié)構(gòu)的基本特征:,1.集合中必存在唯一的一個(gè)“第一元素”;,2.集合中必存在唯一的一個(gè) “最后元素”;,3.除最后元素在外,均有 唯一的后繼;,4.除第一元素之外,均有 唯一的前驅(qū)。,線性結(jié)構(gòu) 是 一個(gè)數(shù)據(jù)元素的有序(次序)集,3,2.1 線性表的類型定義,2.3 線性表類型的實(shí)現(xiàn) ? 鏈?zhǔn)接诚?2.4 一

2、元多項(xiàng)式的表示,2.2 線性表類型的實(shí)現(xiàn) ? 順序映象,4,2.1 線性表的類型定義,5,抽象數(shù)據(jù)類型線性表的定義如下:,ADT List {,數(shù)據(jù)對(duì)象:,D={ ai | ai ∈ElemSet, i=1,2,...,n, n≥0 } //稱 n 為線性表的表長(zhǎng); //稱 n=0 時(shí)的線性表為空表。,數(shù)據(jù)關(guān)系:,R1

3、={ |ai-1 ,ai∈D, i=2,...,n },//設(shè)線性表為 (a1,a2, . . . ,ai,. . . ,an), //稱 i 為 ai 在線性表中的位序。,6,基本操作:,結(jié)構(gòu)初始化操作,結(jié)構(gòu)銷毀操作,引用型操作,更改型操作,,} ADT List,7,InitList( &L ),操作結(jié)果:,構(gòu)造一個(gè)空的線性表L。,初始化操作,,8,結(jié)構(gòu)銷毀操作,DestroyList( &am

4、p;L ),初始條件:操作結(jié)果:,線性表 L 已存在。,銷毀線性表 L。,,9,ListEmpty( L ),ListLength( L ),PriorElem( L, cur_e, &pre_e ),NextElem( L, cur_e, &next_e ),GetElem( L, i, &e ),LocateElem( L, e, compare( ) ),ListTraverse(L, visit( )

5、),,引用型操作:,10,ListEmpty( L ),初始條件:操作結(jié)果:,線性表L已存在。,若L為空表,則返回TRUE,否則FALSE。,,(線性表判空),11,ListLength( L ),初始條件:操作結(jié)果:,線性表L已存在。,返回L中元素個(gè)數(shù)。,,(求線性表的長(zhǎng)度),12,PriorElem( L, cur_e, &pre_e ),初始條件:操作結(jié)果:,線性表L已存在。,若cur_e是L的元素,但不是第

6、一個(gè),則用pre_e 返回它的前驅(qū),否則操作失敗,pre_e無(wú)定義。,,(求數(shù)據(jù)元素的前驅(qū)),13,NextElem( L, cur_e, &next_e ),初始條件:操作結(jié)果:,線性表L已存在。,若cur_e是L的元素,但不是最后一個(gè),則用next_e返回它的后繼,否則操作失敗,next_e無(wú)定義。,,(求數(shù)據(jù)元素的后繼),14,GetElem( L, i, &e ),初始條件: 操作結(jié)果:,線性表L已存在

7、,且 1≤i≤LengthList(L),用 e 返回L中第 i 個(gè)元素的值。,,(求線性表中某個(gè)數(shù)據(jù)元素),15,LocateElem( L, e, compare( ) ),初始條件:操作結(jié)果:,線性表L已存在,e為給定值, compare( )是元素判定函數(shù)。,返回L中第1個(gè)與e滿足關(guān)系compare( )的元素的位序。若這樣的元素不存在,則返回值為0。,,(定位函數(shù)),16,ListTraverse(L, vis

8、it( )),初始條件:操作結(jié)果:,線性表L已存在。Visit() 為某個(gè)訪問(wèn)函數(shù)。,依次對(duì)L的每個(gè)元素調(diào)用函數(shù)visit( )。一旦visit( )失敗,則操作失敗。,,(遍歷線性表),17,更改型操作,ClearList( &L ),PutElem( L, i, &e ),ListInsert( &L, i, e ),ListDelete(&L, i, &e),,18,ClearLis

9、t( &L ),初始條件:操作結(jié)果:,線性表L已存在。,將L重置為空表。,,(線性表置空),19,PutElem( L, i, &e ),初始條件:操作結(jié)果:,線性表L已存在,且 1≤i≤LengthList(L),把e值賦到L中第i個(gè)元素。,,(改變數(shù)據(jù)元素的值),20,ListInsert( &L, i, e ),初始條件:操作結(jié)果:,線性表L已存在,且 1≤i≤LengthList(L)

10、+1,在L的第i個(gè)元素之前插入新的元素e,L的長(zhǎng)度增1。,,(插入數(shù)據(jù)元素),21,ListDelete(&L, i, &e),初始條件:操作結(jié)果:,線性表L已存在且非空,且1≤i≤LengthList(L),刪除L的第i個(gè)元素,并用e返回其值,L的長(zhǎng)度減1。,,(刪除數(shù)據(jù)元素),22,利用上述定義的線性表基本操作 可以實(shí)現(xiàn)其它更復(fù)雜的操作,23,假設(shè):有兩個(gè)集合A和B分別用兩個(gè)線性表LA和LB表示(即:線

11、性表中的數(shù)據(jù)元素即為集合中的成員) 現(xiàn)要求求一個(gè)新的集合A=A∪B。,例 2-1,24,要求對(duì)線性表作如下操作:擴(kuò)大線性表LA,將存在于線性表LB中而不存在于線性表LA中的數(shù)據(jù)元素插入到線性表LA中去。,上述問(wèn)題可演繹為:,25,1.從線性表LB中依次察看每個(gè)數(shù)據(jù)元素;,2.依值在線性表LA中進(jìn)行查訪;,3.若不存在,則插入之。,GetElem(LB, i, &e)→e,LocateElem(LA, e, equal(

12、 )),ListInsert(LA, n+1, e),操作步驟:,26,GetElem(Lb, i, &e); // 取Lb中第i個(gè)數(shù)據(jù)元素賦給e if (!LocateElem(La, e, equal( )) ) ListInsert(La, ++La_len, e); // La中不存在和 e 相同的數(shù)據(jù)元素,則插入之,void union(List &La, List Lb)

13、{ La_len = ListLength(La); Lb_len = ListLength(Lb); // 求線性表的長(zhǎng)度,for (i = 1; i <= Lb_len; i++) {,},} // union,27,已知一個(gè)非純集合 B,試構(gòu)造一個(gè)純集合 A,使 A中只包含 B 中所有值各不相 同的數(shù)據(jù)元素。,課堂練習(xí):,仍選用線性表表示集合,28,GetElem(Lb, i, &e); // 取

14、Lb中第i個(gè)數(shù)據(jù)元素賦給e if (!LocateElem(La, e, equal( )) ) ListInsert(La, ++La_len, e); // La中不存在和 e 相同的數(shù)據(jù)元素,則插入之,for (i = 1; i <= Lb_len; i++) {,},void union(List &La, List Lb) { La_len=ListLen

15、gth(La); Lb_len=ListLength(Lb);,} // union,InitList(La);,29,例2-2 歸并兩個(gè)“其數(shù)據(jù)元素按值非遞減有序排列”的線性表 LA 和 LB,求得線性表 LC 也具有同樣特性。,設(shè) La = (a1, …, ai, …, an) Lb = (b1, …, bj, …, bm) Lc = (c1, …, ck, …, cm+n),則

16、 k = 1, 2, …, m+n,30,1.初始化 LC 為空表;2.分別從 LA和LB中取得當(dāng)前元素 ai 和 bj;3.若 ai≤bj,則將 ai 插入到 LC 中,否則將 bj 插入到 LC 中;4.重復(fù) 2 和 3 兩步,直至 LA 或 LB 中元素

17、 被取完為止;5.將 LA 表或 LB 表中剩余元素復(fù)制插入到 LC 表中。,基本操作:,31,void MergeList(List La, List Lb, List &Lc) { InitList(Lc); i = j = 1; k = 0; La_len = ListLength(La); Lb_len = ListLength(Lb); while ((i

18、<= La_len) && (j <= Lb_len)) { // La和Lb均非空 GetElem(La, i, &ai); GetElem(Lb, j, &bj); if (ai <= bj) { ListInsert(Lc, ++k, ai); ++i; } else { ListI

19、nsert(Lc, ++k, bj); ++j; } },32,while (i <= La_len) { GetElem(La, i++, &ai); ListInsert(Lc, ++k, ai); } // 插入 La 表中剩余元素 while (j <= Lb_len) { GetElem(Lb, j++, &

20、bj); ListInsert(Lc, ++k, bj); } // 插入 Lb 表中剩余元素} // merge_list,33,預(yù)習(xí)題,線性表的順序存儲(chǔ)結(jié)構(gòu)有何特點(diǎn)?“隨機(jī)存取”的含義是什么?復(fù)習(xí)C語(yǔ)言中有關(guān)數(shù)組類型的使用方法。查閱相關(guān)資料,掌握函數(shù)malloc()與realloc()。,34,表示 的最簡(jiǎn)單的一種順序映象方法是: 令 y 的存儲(chǔ)位置和 x 的存儲(chǔ)位置相鄰。,2.2 線性表

21、類型的實(shí)現(xiàn) ----順序映象,35,用一組地址連續(xù)的存儲(chǔ)單元 依次存放線性表中的數(shù)據(jù)元素,a1 a2 … ai-1 ai … an,線性表的起始地址,稱作線性表的基地址,,,,,,,,,,,,,36,以“存儲(chǔ)位置相鄰”表示有序?qū)?即:LOC(ai) = LOC(ai-1) + C 一個(gè)數(shù)據(jù)元素所占存儲(chǔ)量↑ 所有

22、數(shù)據(jù)元素的存儲(chǔ)位置均取決于第一個(gè)數(shù)據(jù)元素的存儲(chǔ)位置 LOC(ai) = LOC(a1) + (i-1)×C ↑基地址,37,順序映像的C語(yǔ)言描述#define LIST_INIT_SIZE 100 // 線性表存儲(chǔ)空間的初始分配量#define LISTINCREMENT 10

23、 // 線性表存儲(chǔ)空間的分配增量typedef struct { ElemType *elem; // 存儲(chǔ)空間基址 int length; // 當(dāng)前長(zhǎng)度 int listsize; // 當(dāng)前分配的存儲(chǔ)容量 //(以sizeof(ElemType)為單位)} SqList; // 俗稱 順序表,38,線性表的初始化

24、操作,Status InitList_Sq( SqList& L ) { // 構(gòu)造一個(gè)空的線性表 L.elem = (ElemType*)malloc(LIST_ INIT_SIZE?sizeof(ElemType)); if (!L.elem) exit(OVERFLOW); L.length = 0; L.listsize = LIST_INIT_SIZE re

25、turn OK;} // InitList_Sq,算法時(shí)間復(fù)雜度:,O(1),39,線性表操作 LocateElem(L, e, compare( )) 的實(shí)現(xiàn):,40,int LocateElem_Sq(SqList L, ElemType e, Status (*compare)(ElemType, ElemType)) { i = 1; // i的初值為第

26、1元素的位序 p = L.elem; // p的初值為第1元素的存儲(chǔ)位置 while (i <= L.length && !(*compare)(*p++, e)) ++i; if (i <= L.length) return i; else return 0; } // LocateElem_Sq,O( L

27、istLength(L) ),算法的時(shí)間復(fù)雜度為:,41,線性表操作 ListInsert(&L, i, e)的實(shí)現(xiàn)。,問(wèn):,插入元素時(shí),線性表的邏輯結(jié)構(gòu)發(fā)生什么變化?,42,(a1, …, ai-1, ai, …, an) 改變?yōu)?(a1, …, ai-1, e, ai, …, an),a1 a2 … ai-1 ai … an,

28、,,,,,,a1 a2 … ai-1,,,,,,,,,,,,ai,,…,,,an,,,,,,e,,,,,,, ,,,表的長(zhǎng)度增加,,43,Status ListInsert_Sq(SqList &L, int pos, ElemType e) { if (pos L.length+1) return ERROR; // 插入位置不合法 if (L.length >= L.list

29、size) { // 當(dāng)前存儲(chǔ)空間已滿,增加分配 newbase = (ElemType *)realloc(L.elem, (L.listsize+LISTINCREMENT)*sizeof (ElemType)); if (!newbase) exit(

30、OVERFLOW); // 存儲(chǔ)分配失敗 L.elem = newbase; // 新基址 L.listsize += LISTINCREMENT; // 增加存儲(chǔ)容量 } q = &(L.elem[pos-1]); // q指示插入位置 for (p = &(L.elem[L

31、.length-1]); p >= q; --p) *(p+1) = *p; // 插入位置及之后的元素右移 *q = e; // 插入e ++L.length; // 表長(zhǎng)增1 return OK; } // ListInsert_Sq,,,44,if (pos L.length+1) return ERROR;

32、 // 插入位置不合法if (L.length >= L.listsize) { // 當(dāng)前存儲(chǔ)空間已滿,增加分配 newbase = (ElemType *)realloc(L.elem, (L.listsize+LISTIN

33、CREMENT)*sizeof (ElemType)); if (!newbase) exit(OVERFLOW); // 存儲(chǔ)分配失敗 L.elem = newbase; // 新基址 L.listsize += LISTINCREMENT; // 增加存儲(chǔ)容量},,45,考慮平均的情況:,假設(shè)在第 i 個(gè)元素之前插入的概

34、率為 則在長(zhǎng)度為n的線性表中插入一個(gè)元素所需移動(dòng)元素次數(shù)的期望值為:,若假定在線性表中任何一個(gè)位置上進(jìn)行插入的概率都是相等的,則移動(dòng)元素的期望值為:,46,線性表操作 ListDelete(&L, i, &e)的實(shí)現(xiàn):,問(wèn):,刪除元素時(shí),線性表的邏輯結(jié)構(gòu)發(fā)生什么變化?,47,(a1, …, ai-1, ai, ai+1, …, an) 改變?yōu)?

35、 (a1, …, ai-1, ai+1, …, an),a1 a2 … ai-1 ai ai+1 … an,,,,,,,a1 a2 … ai-1,,,,,,,,,,,,ai+1,,…,,,an,,,,,,,,,,, ,,,,,表的長(zhǎng)度減少,,48,Status ListDelete_Sq (SqList &L, int pos, ElemType &e) {

36、 if ((pos L.length)) return ERROR; // 刪除位置不合法 p = &(L.elem[pos-1]); // p為被刪除元素的位置 e = *p; // 被刪除元素的值賦給e q = L.elem+L.length-1; // 表尾元素的位置 for (++p

37、; p <= q; ++p) *(p-1) = *p; // 被刪除元素之后的元素左移 --L.length; // 表長(zhǎng)減1 return OK; } // ListDelete_Sq,此算法的時(shí)間復(fù)雜度為:,O( ListLength(L)

38、),49,考慮平均的情況:,,假設(shè)刪除第 i 個(gè)元素的概率為 , 則在長(zhǎng)度為n的線性表中刪除一個(gè)元素所需移動(dòng)元素次數(shù)的期望值為:,若假定在線性表中任何一個(gè)位置上進(jìn)行刪除的概率都是相等的,則移動(dòng)元素的期望值為:,50,算法 ListInsert_Sq 和 ListDelete_Sq 的 時(shí)間復(fù)雜度為:,O( n ),51,順序表的合并(算法2.7),可從算法2.2直接寫出形式上及其相似的算法,如教材P26的算法2.7。

39、 請(qǐng)參看算法演示。 算法時(shí)間復(fù)雜度: O(La.length+Lb.length),52,void MergeList(SqList La,SqList Lb,SqList *Lc) // 算法2.7 { // 已知順序線性表La和Lb的元素按值非遞減排列。//歸并La和Lb得到新的順序線性表Lc,Lc的元素也按值非遞減排列 pa=La.elem

40、; pb=Lb.elem; (*Lc).listsize=(*Lc).length=La.length+Lb.length pc=(*Lc).elem =(ElemType*)malloc((*Lc).listsize*sizeof(ElemType)); if(!(*Lc).elem) exit(OVERFLOW);// 存儲(chǔ)分配失敗 pa_last=La.elem+La.l

41、ength-1; pb_last=Lb.elem+Lb.length-1; while(pa<=pa_last&&pb<=pb_last) { // 表La和表Lb均非空 if (*pa<=*pb) *pc++=*pa++; else *pc++=*pb++; } while(pa<=pa_last) *p

42、c++=*pa++; // 插入La的剩余元素 while(pb<=pb_last) *pc++=*pb++; // 插入Lb的剩余元素 },53,預(yù)習(xí)題,鏈表的存儲(chǔ)結(jié)構(gòu)有何特點(diǎn)?在進(jìn)行鏈表的插入與刪除元素操作時(shí)應(yīng)該特別注意什么操作?什么是頭結(jié)點(diǎn)?它有什么作用?循環(huán)鏈表的結(jié)構(gòu)特點(diǎn)是什么?雙向鏈表的結(jié)構(gòu)特點(diǎn)是什么?鏈表和順序表各基本操作各有什么特點(diǎn)?一元多項(xiàng)式應(yīng)該采用線性表的哪種映象方法來(lái)存儲(chǔ)較適宜?,5

43、4,2.3 線性表類型的實(shí)現(xiàn)----鏈?zhǔn)接诚?55,用一組地址任意的存儲(chǔ)單元存放線性表中的數(shù)據(jù)元素。,a1 a2 … ... an ^,,,,,,,,,,,,,,,,,,,,,,,,,,,,以線性表中第一個(gè)數(shù)據(jù)元素 的存儲(chǔ)地址作為線性表的地址,稱作線性表的頭指針,一、單鏈表,以元素(數(shù)據(jù)元素的映象) + 指針(指示后繼元素存儲(chǔ)位置的) = 結(jié)點(diǎn)(表示數(shù)據(jù)元素 或 數(shù)

44、據(jù)元素的映象),以“結(jié)點(diǎn)的序列”表示線性表??稱作鏈表,頭結(jié)點(diǎn),56,Typedef struct LNode { ElemType data; // 數(shù)據(jù)域 struct Lnode *next; // 指針域 } LNode, *LinkList;,二、結(jié)點(diǎn)和單鏈表的C語(yǔ)言描述,LinkList L; // L 為單鏈表的頭指針,57,線性表的操作 GetElem(L, i,

45、&e)在鏈表中的實(shí)現(xiàn):,三、單鏈表操作的實(shí)現(xiàn),基本操作為: 使指針 p 始終指向 線性表中第 j 個(gè)數(shù)據(jù)元素,58,Status GetElem_L(LinkList L, int pos, ElemType &e) { p = L->next; j = 1; // p 指向第一個(gè)結(jié)點(diǎn),j 為計(jì)數(shù)器 while (p && jnext; ++j; }

46、 // 順指針向后查找,直到 p 指向第 pos 個(gè)元素或 p 為空 if ( !p || j>pos ) return ERROR; // 第pos個(gè)元素不存在 e = p->data; // 取第pos個(gè)元素 return OK;} // GetElem_L,算法的時(shí)間復(fù)雜度為:,O(ListLength(L)),5

47、9,線性表的操作 ListInsert(&L, i, e) 在鏈表中的實(shí)現(xiàn):,有序?qū)?改變?yōu)?和,基本操作為:找到線性表中第i-1 個(gè)結(jié)點(diǎn),修改其指向后繼的指針,60,Status ListInsert_L(LinkList L, int pos, ElemType e) { p = L; j = 0; while (p && j next; ++

48、j; } // 尋找第pos-1個(gè)結(jié)點(diǎn) if (!p || j > pos-1) return ERROR; // pos小于1或者大于表長(zhǎng) s = (LinkList) malloc ( sizeof (LNode)); // 生成新結(jié)點(diǎn) s->data = e; s->next = p->next; // 插入L中

49、 p->next = s; return OK; } // LinstInsert_L,算法的時(shí)間復(fù)雜度為:,O(ListLength(L)),61,線性表的操作ListDelete (&L, i, &e)在鏈表中的實(shí)現(xiàn):,有序?qū)?和 改變?yōu)?,基本操作為:找到線性表中第i-1個(gè)結(jié)點(diǎn),修改其指向后繼的指針。,62,Status ListDelete_L(LinkList L, in

50、t pos, ElemType &e) { p = L; j = 0; while (p->next && j next; ++j; } // 尋找第pos個(gè)結(jié)點(diǎn),并令p指向其前趨 if (!(p->next) || j > pos-1) return ERROR; /

51、/ 刪除位置不合理 q = p->next; p->next = q->next; e = q->data; free(q); // 刪除并釋放結(jié)點(diǎn) return OK; } // ListDelete_L,算法的時(shí)間復(fù)雜度為:,O(ListLength(L)),63,操作 ClearList(&L) 在鏈表中的實(shí)現(xiàn):,void ClearList(&L) {

52、 // 將單鏈表重新置為一個(gè)空表 while (L->next) { p=L->next; L->next=p->next; }} // ClearList,free(p);,算法時(shí)間復(fù)雜度:,O(ListLength(L)),64,如何從線性表得到單鏈表?,鏈表是一個(gè)動(dòng)態(tài)的結(jié)構(gòu),因此生成鏈表的過(guò)程是一個(gè)結(jié)點(diǎn)“逐個(gè)插入” 的過(guò)程。,65,例如:逆位序輸入

53、 n 個(gè)數(shù)據(jù)元素的值,建立帶頭結(jié)點(diǎn)的單鏈表。,操作步驟:,一、建立一個(gè)“空表”;,二、輸入數(shù)據(jù)元素an, 建立結(jié)點(diǎn)并插入;,三、輸入數(shù)據(jù)元素an-1, 建立結(jié)點(diǎn)并插入;,,,,,,,,,,,,,,,,an,,,,,,,,,,an,,an-1,,,,,,四、依次類推,直至輸入a1為止。,66,void CreateList_L(LinkList &L, int n) {} // Creat

54、eList_L,算法的時(shí)間復(fù)雜度為:,O(Listlength(L)),L = (LinkList) malloc (sizeof (LNode));L->next = NULL; // 先建立一個(gè)帶頭結(jié)點(diǎn)的單鏈表,for (i = n; i > 0; --i) { p = (LinkList) malloc (sizeof (LNode)); scanf(&p->data); /

55、/ 輸入元素值 p->next = L->next; L->next = p; //插入},67,用上述定義的單鏈表實(shí)現(xiàn)線性表的操作時(shí),存在的問(wèn)題:,改進(jìn)鏈表的設(shè)置:,1.單鏈表的表長(zhǎng)是一個(gè)隱含的值;,1.增加“表長(zhǎng)”、“表尾指針” 和 “當(dāng)前位置的 指針” 三個(gè)數(shù)據(jù)域;,2.在單鏈表的最后一個(gè)元素之后插入元素時(shí), 需遍歷整個(gè)鏈表;,3.在鏈表中,元素的“位序”概念淡化,結(jié)點(diǎn)的

56、 “位置”概念加強(qiáng)。,2.將基本操作中的“位序i”改變?yōu)椤爸羔榩”。,68,四、一個(gè)帶頭結(jié)點(diǎn)的線性鏈表類型,typedef struct LNode { // 結(jié)點(diǎn)類型 ElemType data; struct LNode *next;} *Link, *Position;,Status MakeNode( Link &p, ElemType e ); // 分配由p指向的值

57、為e的結(jié)點(diǎn),并返回OK; // 若分配失敗,則返回ERROR,void FreeNode( Link &p ); // 釋放p所指結(jié)點(diǎn),69,typedef struct { // 鏈表類型 Link head, tail; // 分別指向頭結(jié)點(diǎn)和 // 最后一個(gè)結(jié)點(diǎn)的指針 int l

58、en; // 指示鏈表長(zhǎng)度 Link current; // 指向當(dāng)前被訪問(wèn)的結(jié)點(diǎn) //的指針,初始位置指向頭結(jié)點(diǎn)} LinkList;如果不特別聲明的話,那么以后各節(jié)中討論的單鏈表都指的是這種帶頭結(jié)點(diǎn)的鏈表。,70,鏈表的基本操作:,{結(jié)構(gòu)初始化和銷毀結(jié)構(gòu)},Status InitList( LinkList &L );

59、// 構(gòu)造一個(gè)空的線性鏈表 L,其頭指針、 // 尾指針和當(dāng)前指針均指向頭結(jié)點(diǎn), // 表長(zhǎng)為零。,Status DestroyList( LinkList &L ); // 銷毀線性鏈表 L,L不再存在。,O(1),O(n),71,{引用型操作},Status ListEmpty ( LinkList L );//判表空,int ListLength( LinkList L ); // 求表長(zhǎng),Statu

60、s Prior( LinkList L ); // 改變當(dāng)前指針指向其前驅(qū),Status Next ( LinkList L ); // 改變當(dāng)前指針指向其后繼,ElemType GetCurElem ( LinkList L ); // 返回當(dāng)前指針?biāo)笖?shù)據(jù)元素,O(1),O(1),O(n),O(

61、1),O(1),72,Status LocatePos( LinkList L, int i ); // 改變當(dāng)前指針指向第i個(gè)結(jié)點(diǎn),Status LocateElem (LinkList L, ElemType e, Status (*compare)(ElemType, ElemType)); // 若存在與e 滿足函數(shù)compare( )判定關(guān)系的元 // 素,則移

62、動(dòng)當(dāng)前指針指向第1個(gè)滿足條件的 // 元素的前驅(qū),并返回OK; 否則返回ERROR,Status ListTraverse(LinkList L, Status(*visit)() ); // 依次對(duì)L的每個(gè)元素調(diào)用函數(shù)visit(),O(n),O(n),O(n),73,{更改型操作},Status ClearList ( LinkList &L ); // 重置 L 為空表,Sta

63、tus SetCurElem(LinkList &L, ElemType e ); // 更新當(dāng)前指針?biāo)笖?shù)據(jù)元素,Status Append ( LinkList &L, Link s ); // 在表尾元素之后鏈接一串結(jié)點(diǎn),Status InsAfter ( LinkList &L, Elemtype e );

64、 // 將元素 e 插入在當(dāng)前指針之后,Status DelAfter ( LinkList &L, ElemType& e ); // 刪除當(dāng)前指針之后的結(jié)點(diǎn),O(1),O(n),O(n),O(1),O(1),74,Status InsAfter( LinkList& L, ElemType e ) { // 若當(dāng)前指針在鏈表中,則將數(shù)據(jù)元素e插入在線性鏈

65、 // 表L中當(dāng)前指針?biāo)附Y(jié)點(diǎn)之后,并返回OK; // 否則返回ERROR。 } // InsAfter,if ( ! L.current ) return ERROR; if (! MakeNode( s, e) ) return ERROR; s->next = L.current->next; L.current->next = s; if (L.tail = L.c

66、urrent) L.tail = s; L.current = s; return OK;,75,Status DelAfter( LinkList& L, ElemType& e ) { // 若當(dāng)前指針及其后繼在鏈表中,則刪除線性鏈表L中當(dāng)前 // 指針?biāo)附Y(jié)點(diǎn)之后的結(jié)點(diǎn),并返回OK; 否則返回ERROR。 if ( !(L.current && L.current->

67、;next ) ) return ERROR; q = L.current->next; L.current->next = q->next; if (L.tail = q) L.tail = L.current; e=q->data; FreeNode(q); return OK;} //DelAfter,76,最后一個(gè)結(jié)點(diǎn)的指針域的指針又指回第一個(gè)結(jié)

68、點(diǎn)的鏈表,a1 a2 … ... an ^,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,1. 循環(huán)鏈表,五、其它形式的鏈表,77,2. 雙向鏈表,typedef struct DuLNode { ElemType data; // 數(shù)據(jù)域 struct DuLNode *prior;

69、 // 指向前驅(qū)的指針域 struct DuLNode *next; // 指向后繼的指針域} DuLNode, *DuLinkList;,,,,,,,,,,,,,,78,雙向循環(huán)鏈表,空表,非空表,a1 a2 … ... an ^,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,

70、,,,,,,,,,,,79,課堂練習(xí),1.將一個(gè)單鏈表按逆序鏈接,即若原單鏈表中存儲(chǔ)元素的次序?yàn)閍1,a2,...an,則逆序鏈接后變?yōu)閍n,an-1,...a1。,80,【思路分析】,讀入當(dāng)前結(jié)點(diǎn),并將當(dāng)前結(jié)點(diǎn)插入到表頭,這樣最先插入的結(jié)點(diǎn)成為表尾,最后插入的結(jié)點(diǎn)成為表頭。,81,【解答】,Status Contray ( LinkList &head ) { // 將單鏈表中所有結(jié)點(diǎn)逆置,成功則返回OK p =

溫馨提示

  • 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ù)僅提供信息存儲(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ì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論