java鏈表的頭插法和尾插法詳解
java鏈表的頭插法和尾插法
鏈表是由值和地址組成,地址指向下一個值的地址,
如下圖所示:

我們先定義一個節(jié)點(diǎn)類Listnode,里面包含值和地址屬性,再通過構(gòu)造器傳值為這個值在內(nèi)存中申請一塊區(qū)域。
代碼如下:
public class Listnode {
//鏈表中一個節(jié)點(diǎn)的值屬性
public int value;
//鏈表中一個節(jié)點(diǎn)的指針域?qū)傩?,指向下一個值的地址,因為下一塊區(qū)域是Listnode類型的所以next也是Listnode類型
public Listnode next;
//構(gòu)造器,通過值傳遞給value賦值
public Listnode(int n) {
this.value=n;
}
}先創(chuàng)建一個鏈表類Linklist
頭插法的思路是定義一個頭指針Listnode head=null,把第一個節(jié)點(diǎn)的地址通過值傳遞給它,再創(chuàng)建節(jié)點(diǎn)時,讓這個新節(jié)點(diǎn)的next指針指向舊節(jié)點(diǎn),再讓這個頭指針指向新節(jié)點(diǎn)。
如下圖:



頭插法看如下
代碼:
public void startAdd(int n) {
//通過new實例給value創(chuàng)建一個新節(jié)點(diǎn)
Listnode listnode=new Listnode(n);
//讓新節(jié)點(diǎn)的下一個指向舊節(jié)點(diǎn),因為舊節(jié)點(diǎn)通過值傳遞的方式傳給head
listnode.next=head;
//新節(jié)點(diǎn)通過值傳遞的方式傳給head
head=listnode;
}尾插法的思路是先定義一個游標(biāo)temp,游標(biāo)從頭結(jié)點(diǎn)head開始,如果它的next指針域不是null,就讓游標(biāo)指向下一個,直到游標(biāo)指向next指針域為null,然后在這個節(jié)點(diǎn)后插入新的節(jié)點(diǎn)。



尾插法代碼
如下:
public void endAdd(int n) {
//通過new實例給value創(chuàng)建一個新節(jié)點(diǎn)
Listnode listnode=new Listnode(n);
//判斷頭結(jié)點(diǎn)是否為空,空就通過值傳遞把新節(jié)點(diǎn)傳給頭節(jié)點(diǎn),直接return不再走下面的流程
if(head==null) {
head=listnode;
return;
}
//定義游標(biāo)
Listnode temp=head;
//通過游標(biāo)判斷此節(jié)點(diǎn)的next指針域是否為空,不是就指向下一個節(jié)點(diǎn)
while(temp.next!=null) {
temp=temp.next;
}
//此時指向最后一個節(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+"個數(shù)");
}
}通過test類來測試一下:
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é)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java分頁簡介_動力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要為大家詳細(xì)介紹了Java分頁簡介的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-08-08
Springboot配置管理Externalized?Configuration深入探究
這篇文章主要介紹了Springboot配置管Externalized?Configuration深入探究,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-01-01
Java基礎(chǔ)教程之對象的方法與數(shù)據(jù)成員
這篇文章主要介紹了Java基礎(chǔ)教程之對象的方法與數(shù)據(jù)成員,本文講解對象的方法與數(shù)據(jù)成員相關(guān)知識,因為java是面向?qū)ο笳Z言,本文的知識都是經(jīng)常要用到的,需要的朋友可以參考下2014-08-08
SpringBoot 對象存儲 MinIO的詳細(xì)過程
MinIO 是一個基于 Go 實現(xiàn)的高性能、兼容 S3 協(xié)議的對象存儲,它適合存儲海量的非結(jié)構(gòu)化的數(shù)據(jù),這篇文章主要介紹了SpringBoot 對象存儲 MinIO,需要的朋友可以參考下2023-07-07

