




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
//在不確定數(shù)據(jù)域數(shù)值的情況下,采用泛型定義publicclassNode<E>{Edata;//數(shù)據(jù)域Node<E>next;//指針域}datanext單個(gè)節(jié)點(diǎn)的表示方法//在不確定數(shù)據(jù)域數(shù)值的情況下,采用泛型定義publicclassLinkList<E>{ Node<E>head;Node<E>p;}datanext單個(gè)節(jié)點(diǎn)的表示方法datanextdatanextheadnull建立鏈表datanextheadNULLnewnode//說(shuō)明head頭指針newnode新節(jié)點(diǎn)指針newnode.data數(shù)據(jù)域表示方式newnode.next指針域表示方式NULLnewnode無(wú)后繼節(jié)點(diǎn)headNULLPNULL初始狀態(tài),無(wú)節(jié)點(diǎn)
head=NULL;P=NULL;publicLinkList(){head=null;p=null;}初始化datanextheadNULLpnewode建立鏈表publicvoidaddhead(Node<E>e){Node<E>newhead=newNode<E>();newhead.data=e.data;newhead.next=e.next;head=newhead;p=head;p.next=null;}遍歷輸出publicvoidprintlist(){ p=head; if(head==null) {System.out.println("這是一個(gè)空鏈表"); }while(p!=null)
{System.out.println(p.data); p=p.next; }}在鏈表后面插入節(jié)點(diǎn)datanextheadNULLnewnodedatanextp注意:添加節(jié)點(diǎn)后,鏈表的長(zhǎng)度+1publicvoidaddlist(Node<E>e){Node<E>newnode=newNode<E>();newnode.data=e.data;newnode.next=e.next;p.next=newnode;p=p.next;p.next=null;}publicstaticvoidmain(String[]args){ScannerAA=newScanner(System.in);LinkList<Integer>obj1=newLinkList<Integer>();Node<Integer>tt=newNode<Integer>();System.out.print("請(qǐng)輸入第1數(shù):");tt.data=AA.nextInt();obj1.addhead(tt);Node<Integer>tb=newNode<Integer>();intk;inti=2;do{System.out.print("請(qǐng)輸入第"+i+"數(shù):");k=AA.nextInt();if(k==0)break;tb.data=k;obj1.addlist(tb);i++;}while(true);此段代碼:表示連續(xù)建立多個(gè)節(jié)點(diǎn),知道輸入的數(shù)字為0,就不再建立新的節(jié)點(diǎn)obj1.printlist();System.out.print("請(qǐng)輸入第插入節(jié)點(diǎn)的值");tb.data=AA.nextInt();obj1.addnode(tb,2);obj1.printlist();System.out.print("請(qǐng)輸入首節(jié)點(diǎn)插入的值");tb.data=AA.nextInt();obj1.addH(tb);obj1.printlist();}單鏈表的插入(1)只定節(jié)點(diǎn)后插入新的節(jié)點(diǎn)圖示
s.next=p.next;p.next=s;(2)前插結(jié)點(diǎn)
(2)只定節(jié)點(diǎn)前插入新的節(jié)點(diǎn)圖示
s.next=p;q.next=s;單鏈表的刪除
q.next=p.next;p.next=null;單鏈表的按值查找操作 }
單鏈表操作的效率分析
(1)單鏈表是一種順序存取結(jié)構(gòu),不是隨機(jī)存取結(jié)構(gòu)。要訪問(wèn)任意一個(gè)結(jié)點(diǎn)ai(1≤i≤n),必須從頭指針head開(kāi)始,沿著“鏈”的方向逐個(gè)查找,執(zhí)行i-1次p=p.getNext()操作,平均進(jìn)行n/2次。(2)單鏈表的插入和刪除操作,必須知道其直接前驅(qū)結(jié)點(diǎn)。(3)與順序表相比,單鏈表中結(jié)點(diǎn)的存儲(chǔ)空間是動(dòng)態(tài)申請(qǐng)和釋放的,不需要預(yù)先分配。同時(shí),對(duì)單鏈表執(zhí)行插入和刪除操作時(shí),只需要改變相關(guān)結(jié)點(diǎn)的“鏈”,不需要移動(dòng)結(jié)點(diǎn)。因此,單鏈表在一定程度上可以提高運(yùn)行效率和存儲(chǔ)空間的利用率。循環(huán)鏈表
head是單鏈表的頭指針,設(shè)rear是單鏈表的尾指針。將單鏈表中最后一個(gè)結(jié)點(diǎn)的指針域指回鏈表的頭結(jié)點(diǎn),即rear.next=head,則整個(gè)單鏈表頭尾相連形成了一個(gè)環(huán),就構(gòu)成了循環(huán)單鏈表。
雙向鏈表
在單鏈表中,從任意一個(gè)結(jié)點(diǎn)出發(fā)都能通
溫馨提示
- 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年銀川中考英語(yǔ)試卷及答案
- 上料崗位考試試題及答案
- 2025年南航藝術(shù)考研真題及答案
- 2025年大學(xué)干部考試題型及答案
- 青州中考模擬考試題目及答案
- 2025年高考語(yǔ)文棋盤(pán)真題及答案
- 2025年紀(jì)委干部考試試題及答案
- 2025年成人政治高考真題及答案
- 化學(xué)實(shí)驗(yàn)基礎(chǔ)能力提升試題
- 2025年高三物理上學(xué)期“材料科學(xué)與物理”科普測(cè)試卷
- 2025年“10.13建隊(duì)日”分批入隊(duì)活動(dòng)總結(jié):強(qiáng)國(guó)復(fù)興有我爭(zhēng)當(dāng)新時(shí)代好少年
- 2024年服裝時(shí)裝項(xiàng)目資金籌措計(jì)劃書(shū)代可行性研究報(bào)告
- 施工三方協(xié)議7篇
- 2025年數(shù)字娛樂(lè)行業(yè)數(shù)字化娛樂(lè)內(nèi)容與虛擬現(xiàn)實(shí)體驗(yàn)研究報(bào)告
- 法學(xué)專(zhuān)業(yè)考試題型及答案
- 2.1流水地貌課件高中地理湘教版必修一
- 外科學(xué)考試大綱
- 使用吹風(fēng)機(jī)勞動(dòng)課件
- 2024版2025秋貴州黔教版綜合實(shí)踐活動(dòng)二年級(jí)上冊(cè)全冊(cè)教案教學(xué)設(shè)計(jì)
- 3D打印簡(jiǎn)介課件
- 2025年貴州省貴陽(yáng)市輔警考試題庫(kù)(附答案)
評(píng)論
0/150
提交評(píng)論