欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java鏈表的頭插法和尾插法詳解

 更新時(shí)間:2024年12月17日 09:32:27   作者:Sshm_666  
本文介紹了鏈表的基本概念,包括節(jié)點(diǎn)類(lèi)Listnode和鏈表類(lèi)Linklist,頭插法和尾插法是兩種常見(jiàn)的插入節(jié)點(diǎn)的方法,分別通過(guò)頭指針和游標(biāo)來(lái)實(shí)現(xiàn),通過(guò)示例代碼和測(cè)試,展示了鏈表的創(chuàng)建和操作過(guò)程

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 循環(huán)結(jié)構(gòu)

    淺析JAVA 循環(huán)結(jié)構(gòu)

    這篇文章主要介紹了JAVA 循環(huán)結(jié)構(gòu)的相關(guān)資料,文中講解的非常細(xì)致,示例代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • Java使用FFmpeg提取音頻的詳細(xì)指南

    Java使用FFmpeg提取音頻的詳細(xì)指南

    FFmpeg 是一個(gè)開(kāi)源的多媒體處理工具,支持視頻、音頻的編碼、解碼、轉(zhuǎn)換等多種功能,本文將詳細(xì)講解如何使用 FFmpeg 提取音頻,包括常見(jiàn)的音頻格式提取、音頻質(zhì)量調(diào)整、高級(jí)處理操作等,內(nèi)容淺顯易懂,適合初學(xué)者快速掌握,需要的朋友可以參考下
    2024-11-11
  • Java分頁(yè)簡(jiǎn)介_(kāi)動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

    Java分頁(yè)簡(jiǎn)介_(kāi)動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

    這篇文章主要為大家詳細(xì)介紹了Java分頁(yè)簡(jiǎn)介的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • Springboot配置管理Externalized?Configuration深入探究

    Springboot配置管理Externalized?Configuration深入探究

    這篇文章主要介紹了Springboot配置管Externalized?Configuration深入探究,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2024-01-01
  • Java基礎(chǔ)教程之對(duì)象的方法與數(shù)據(jù)成員

    Java基礎(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ān)于JDBC的簡(jiǎn)單封裝(實(shí)例講解)

    下面小編就為大家?guī)?lái)一篇關(guān)于JDBC的簡(jiǎn)單封裝(實(shí)例講解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-08-08
  • java 如何判斷是否是26個(gè)英文字母

    java 如何判斷是否是26個(gè)英文字母

    這篇文章主要介紹了java 如何判斷是否是26個(gè)英文字母的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-01-01
  • Kotlin 基礎(chǔ)語(yǔ)法詳細(xì)介紹

    Kotlin 基礎(chǔ)語(yǔ)法詳細(xì)介紹

    這篇文章主要介紹了Kotlin 基礎(chǔ)語(yǔ)法詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • 一文詳解SpringBoot3如何自定義starter

    一文詳解SpringBoot3如何自定義starter

    在Spring Boot中,starter是一種特殊的依賴(lài),它可以幫助開(kāi)發(fā)人員快速引入和配置某個(gè)特定的功能模塊,我們?cè)诿嬖囍型ㄟ^(guò)會(huì)被問(wèn)到SpringBoot3如何自定義starter,所以本文小編給大家詳細(xì)介紹了SpringBoot3自定義starter的步驟,需要的朋友可以參考下
    2024-09-09
  • SpringBoot 對(duì)象存儲(chǔ) MinIO的詳細(xì)過(guò)程

    SpringBoot 對(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

最新評(píng)論