數(shù)據(jù)結(jié)構(gòu)作業(yè)_第1頁
數(shù)據(jù)結(jié)構(gòu)作業(yè)_第2頁
數(shù)據(jù)結(jié)構(gòu)作業(yè)_第3頁
數(shù)據(jù)結(jié)構(gòu)作業(yè)_第4頁
數(shù)據(jù)結(jié)構(gòu)作業(yè)_第5頁
免費(fèi)預(yù)覽已結(jié)束,剩余36頁可下載查看

下載本文檔

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

文檔簡介

1、需要額外表示相鄰需要額外表示相鄰關(guān)系的數(shù)鏈節(jié)點(diǎn)數(shù)據(jù)元素(Elem_type)+相鄰關(guān)系信息所有節(jié)點(diǎn)均只含有一個(gè)指針域的鏈表m1324內(nèi)對示示所有節(jié)點(diǎn)均只含有一個(gè)指針域的鏈表m1324內(nèi)對示示aaaa節(jié)點(diǎn)結(jié)data :數(shù)據(jù)域,存放結(jié)點(diǎn)的值next:指針域,存放結(jié)點(diǎn)節(jié)點(diǎn)結(jié)data :數(shù)據(jù)域,存放結(jié)點(diǎn)的值next:指針域,存放結(jié)點(diǎn)的直接后繼的地也有next域?qū)懗蒷ink域的寫/*數(shù)據(jù)域,保存結(jié)點(diǎn)的值 /*指針/*數(shù)據(jù)域,保存結(jié)點(diǎn)的值 /*指針域structnode11定義是遞_21指向該結(jié)構(gòu)的指針該節(jié)點(diǎn)及之后的節(jié)點(diǎn))31整可用一個(gè)指向第一個(gè)節(jié)點(diǎn)的指針來標(biāo)識/定節(jié)點(diǎn)的基q操作各類數(shù)據(jù)結(jié)均o節(jié)點(diǎn)的基q操

2、作各類數(shù)據(jù)結(jié)均o封裝空節(jié)點(diǎn)指針(空鏈表,長度list_node*my_node=21分配節(jié)點(diǎn)(動(dòng)態(tài)內(nèi)存分配)my_node = my_node-data = my_node-next=my_node-data = my_node-next=內(nèi)存的ltypedef list_node* l 基q操作的的ltypedef list_node* l 基q操作的實(shí)現(xiàn)(實(shí)現(xiàn)線性表ADT操作l初始化l查找某元素O置,刪除元素,求長l銷毀,判斷空表,取表中第i個(gè)元素等取某Ol取某Ol 非隨機(jī)存取,無法直接利用Ol方法從第一個(gè)節(jié)點(diǎn)開始,依次找向OSus ,i,) return k=1;link_node*pS

3、us ,i,) return k=1;link_node*p;while(knext=;/m 第一種情況1newnode-next=;/修pp()pp()p(pp(p)(boolInsert(link_list, Elem_type i)boolInsert(link_list, Elem_type i)k =p=p-xlink_node*p=;while(p&kdata = x;/創(chuàng)建新list_node*newnodenewnode-data = x;if (i=1) newnode-next=;*= else newnode-next=p-else newnode-next=p-p-ne

4、xt=returnERROR;/空鏈表, return OK;m刪m第一種情況1 個(gè)元素改變指向鏈表第一個(gè)元素指針m第二種情況: 刪除表中或m刪m第一種情況1 個(gè)元素改變指向鏈表第一個(gè)元素指針m第二種情況: 刪除表中或ai-aai-paq除ai在點(diǎn)SusDelete*,i, Elem_type *x) /刪除指定O置link_node *p, SusDelete*,i, Elem_type *x) /刪除指定O置link_node *p, /p指向操作節(jié)點(diǎn),q指向被刪除節(jié)1if(i=q=/先保留節(jié)點(diǎn);*=elsep=;k =&elsep=;k =&knext)/無i-1/i節(jié)if(p|p-ne

5、xt)/無i-1/i節(jié)f(next=q-/刪除x /刪除x =q-return OK;刪除元素等比較繁瑣其他操作課后自行實(shí)現(xiàn)對結(jié)點(diǎn)的鏈表,對一些概念做如O區(qū)分L對結(jié)點(diǎn)的鏈表,對一些概念做如O區(qū)分L指向Head節(jié)點(diǎn)的指首元素指針-指向頭結(jié)點(diǎn)直接后繼節(jié)點(diǎn)-p元素指針-指向尾節(jié)點(diǎn)直接前驅(qū)節(jié)點(diǎn)-p,last,tail,對應(yīng)中文的頭1首1第一1尾1p1帶結(jié)構(gòu)/操作實(shí)現(xiàn)時(shí)可選的一種約定Sus init(帶結(jié)構(gòu)/操作實(shí)現(xiàn)時(shí)可選的一種約定Sus init(link_list if(*my_list = (*my_list)-next=NULL; return OK;init時(shí),初始化一個(gè)頭結(jié)點(diǎn),也可以P37找

6、到current節(jié)點(diǎn)i-1位置找到current節(jié)點(diǎn)i-1位置3, 4. new_node賦值5.current-next=時(shí)間復(fù)雜度還須v斷邊/內(nèi)存分配是否成Susinsert(link_listlink_listp=L; Susinsert(link_listlink_listp=L; i, ElemType j=0;/一般均cy指針,O直p=p-next;j+;link_list new_node = new_node-data=return OK;new_node-next=p-尋找i-1節(jié)O1,空間刪除元(pp-next;/保節(jié)p-next刪除元(pp-next;/保節(jié)p-nextq

7、-next;/改鏈 free(q); /r除時(shí)間復(fù)雜度pqi, ElemType *e)/給定O置Susdelete_index(link_listlink_listp=L,i, ElemType *e)/給定O置Susdelete_index(link_listlink_listp=L,while(p&jnext=p-p-next=假采用append函數(shù),仿照頭插法及insert函數(shù)則us 假采用append函數(shù),仿照頭插法及insert函數(shù)則us L/類C偽Sscanf(%d, append(L, return /算法時(shí)間復(fù)雜度/先找到最后一個(gè)節(jié)點(diǎn)指針/condition條件自行定/先找到

8、最后一個(gè)節(jié)點(diǎn)指針/condition條件自行定scanf(%d, new_node = (list_node*)malloc(sizeof(list_node); if(new_node=NULL)returnERROR;new_node-data=new_node-next=current-next=current=鏈表P順序表比l鏈表P順序表比l l l鏈表P順序表比l ll順序表l鏈表鏈表P順序表比l ll順序表l鏈表密空間是靜態(tài)/動(dòng)態(tài)分配空間(一般來說)是動(dòng)態(tài)分配l量/結(jié)點(diǎn)結(jié)構(gòu)所占的l順序l鏈表鏈表P順序鏈表P順序表比l 實(shí)際l順序表o=(MAX_SIZE - l鏈表o利= (ELEMENT_SIZE - 鏈表P順序表比鏈表P順序表比l 基于l 存取l給定O置i,順序表可以隨機(jī)存取效率高O(1) l給定O置i,鏈表無法隨機(jī)存取效率PO(n)/刪除時(shí)移動(dòng)元素個(gè)l順序表平均需要移動(dòng)近一半元素效率l鏈表O需移動(dòng)元素,只需修改指針效率高l鏈表P順序表比各有優(yōu)劣,O同情形O用O同鏈表P順序表比各有優(yōu)劣,O同

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論