java鏈表的頭插法和尾插法詳解
java鏈表的頭插法和尾插法
鏈表是由值和地址組成,地址指向下一個(gè)值的地址,
如下圖所示:
我們先定義一個(gè)節(jié)點(diǎn)類(lèi)Listnode,里面包含值和地址屬性,再通過(guò)構(gòu)造器傳值為這個(gè)值在內(nèi)存中申請(qǐng)一塊區(qū)域。
代碼如下:
public class Listnode { //鏈表中一個(gè)節(jié)點(diǎn)的值屬性 public int value; //鏈表中一個(gè)節(jié)點(diǎn)的指針域?qū)傩?,指向下一個(gè)值的地址,因?yàn)橄乱粔K區(qū)域是Listnode類(lèi)型的所以next也是Listnode類(lèi)型 public Listnode next; //構(gòu)造器,通過(guò)值傳遞給value賦值 public Listnode(int n) { this.value=n; } }
先創(chuàng)建一個(gè)鏈表類(lèi)Linklist
頭插法的思路是定義一個(gè)頭指針Listnode head=null,把第一個(gè)節(jié)點(diǎn)的地址通過(guò)值傳遞給它,再創(chuàng)建節(jié)點(diǎn)時(shí),讓這個(gè)新節(jié)點(diǎn)的next指針指向舊節(jié)點(diǎn),再讓這個(gè)頭指針指向新節(jié)點(diǎn)。
如下圖:
頭插法看如下
代碼:
public void startAdd(int n) { //通過(guò)new實(shí)例給value創(chuàng)建一個(gè)新節(jié)點(diǎn) Listnode listnode=new Listnode(n); //讓新節(jié)點(diǎn)的下一個(gè)指向舊節(jié)點(diǎn),因?yàn)榕f節(jié)點(diǎn)通過(guò)值傳遞的方式傳給head listnode.next=head; //新節(jié)點(diǎn)通過(guò)值傳遞的方式傳給head head=listnode; }
尾插法的思路是先定義一個(gè)游標(biāo)temp,游標(biāo)從頭結(jié)點(diǎn)head開(kāi)始,如果它的next指針域不是null,就讓游標(biāo)指向下一個(gè),直到游標(biāo)指向next指針域?yàn)閚ull,然后在這個(gè)節(jié)點(diǎn)后插入新的節(jié)點(diǎn)。
尾插法代碼
如下:
public void endAdd(int n) { //通過(guò)new實(shí)例給value創(chuàng)建一個(gè)新節(jié)點(diǎn) Listnode listnode=new Listnode(n); //判斷頭結(jié)點(diǎn)是否為空,空就通過(guò)值傳遞把新節(jié)點(diǎn)傳給頭節(jié)點(diǎn),直接return不再走下面的流程 if(head==null) { head=listnode; return; } //定義游標(biāo) Listnode temp=head; //通過(guò)游標(biāo)判斷此節(jié)點(diǎn)的next指針域是否為空,不是就指向下一個(gè)節(jié)點(diǎn) while(temp.next!=null) { temp=temp.next; } //此時(shí)指向最后一個(gè)節(jié)點(diǎn),讓它的next指針域指向新節(jié)點(diǎn) temp.next=listnode; }
總體代碼如下:
public class Linklist { //定義頭指針 Listnode head; //頭插法 public void endAdd(int n) { Listnode listnode=new Listnode(n); if(head==null) { head=listnode; return; } Listnode temp=head; while(temp.next!=null) { temp=temp.next; } temp.next=listnode; } //尾插法 public void startAdd(int n) { Listnode listnode=new Listnode(n); listnode.next=head; head=listnode; } //把添加的值打印的方法 public void printLink() { Listnode temp=head; while(temp!=null) { System.out.print(temp.value+" "); temp=temp.next; } } //獲取添加多少數(shù)的方法 public void getLength() { int count=0; if(head==null) { System.out.println(0); return; } Listnode temp=head; while(temp!=null) { count++; temp=temp.next; } System.out.println("你添加了"+count+"個(gè)數(shù)"); } }
通過(guò)test類(lèi)來(lái)測(cè)試一下:
public class Test { public static void main(String[] args) { Linklist linklist=new Linklist(); linklist.endAdd(1); linklist.endAdd(2); linklist.endAdd(3); linklist.endAdd(4); linklist.startAdd(2); linklist.startAdd(3); linklist.startAdd(4); linklist.printLink(); linklist.getLength(); } }
結(jié)果如下:
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java分頁(yè)簡(jiǎn)介_(kāi)動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要為大家詳細(xì)介紹了Java分頁(yè)簡(jiǎn)介的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08Springboot配置管理Externalized?Configuration深入探究
這篇文章主要介紹了Springboot配置管Externalized?Configuration深入探究,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-01-01Java基礎(chǔ)教程之對(duì)象的方法與數(shù)據(jù)成員
這篇文章主要介紹了Java基礎(chǔ)教程之對(duì)象的方法與數(shù)據(jù)成員,本文講解對(duì)象的方法與數(shù)據(jù)成員相關(guān)知識(shí),因?yàn)閖ava是面向?qū)ο笳Z(yǔ)言,本文的知識(shí)都是經(jīng)常要用到的,需要的朋友可以參考下2014-08-08關(guān)于JDBC的簡(jiǎn)單封裝(實(shí)例講解)
下面小編就為大家?guī)?lái)一篇關(guān)于JDBC的簡(jiǎn)單封裝(實(shí)例講解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-08-08SpringBoot 對(duì)象存儲(chǔ) MinIO的詳細(xì)過(guò)程
MinIO 是一個(gè)基于 Go 實(shí)現(xiàn)的高性能、兼容 S3 協(xié)議的對(duì)象存儲(chǔ),它適合存儲(chǔ)海量的非結(jié)構(gòu)化的數(shù)據(jù),這篇文章主要介紹了SpringBoot 對(duì)象存儲(chǔ) MinIO,需要的朋友可以參考下2023-07-07