亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java數(shù)據(jù)結(jié)構(gòu)之單鏈表詳解

 更新時(shí)間:2021年05月17日 11:26:37   作者:rain67  
在之前的學(xué)習(xí)中,我們主要了解了很多 Java 的 基本語(yǔ)法,但是在之后的 Java學(xué)習(xí)中,了解基礎(chǔ)數(shù)據(jù)結(jié)構(gòu)的知識(shí)非常重要,數(shù)據(jù)結(jié)構(gòu)的思想可以幫助我們更加清晰明白的了解 Java 的解題思路等等.今天我們就來(lái)開(kāi)始學(xué)習(xí)實(shí)現(xiàn)一個(gè)Java基礎(chǔ)的單鏈表,需要的朋友可以參考下

一、圖示

在這里插入圖片描述

二、鏈表的概念及結(jié)構(gòu)

鏈表是一種物理存儲(chǔ)結(jié)構(gòu)上非連續(xù)存儲(chǔ)結(jié)構(gòu),數(shù)據(jù)元素的邏輯順序是通過(guò)鏈表中的引用鏈接次序?qū)崿F(xiàn)的 。

實(shí)際中鏈表的結(jié)構(gòu)非常多樣,以下情況組合起來(lái)就有8種鏈表結(jié)構(gòu):

單向、雙向

帶頭、不帶頭

循環(huán)、非循環(huán)

今天,我們實(shí)現(xiàn)的是一個(gè) 單向 無(wú)頭 非循環(huán)的鏈表。

下面是此鏈表的結(jié)構(gòu)組成。

在這里插入圖片描述

三、單鏈表的實(shí)現(xiàn)

(1)定義一個(gè)節(jié)點(diǎn)類(lèi)型

我們創(chuàng)建一個(gè) ListNode 的類(lèi)作為節(jié)點(diǎn)類(lèi)型,那么我們?nèi)绾味x成員屬性呢?

通過(guò)上面的結(jié)構(gòu)分析,我們需要定義兩個(gè)成員變量 val --作為該節(jié)點(diǎn)的存儲(chǔ)的數(shù)值, next – 保存下一個(gè)節(jié)點(diǎn)的地址/引用。

同時(shí)定義之后,他們的默認(rèn)值為 0 ,null ,所以要想賦予這個(gè)節(jié)點(diǎn)數(shù)值,要寫(xiě)一個(gè)構(gòu)造方法去首先保存數(shù)值。

在這里插入圖片描述

這里我們提供了兩個(gè)構(gòu)造方法,一個(gè)是實(shí)現(xiàn)提供數(shù)值的節(jié)點(diǎn),另一個(gè)是沒(méi)有提供數(shù)值的節(jié)點(diǎn),方便我們之后使用。

之后我們?cè)?MyListNode 的類(lèi)中實(shí)現(xiàn)單鏈表的各種方法。

在這里插入圖片描述

(2)頭插法

在這里插入圖片描述

以上述結(jié)構(gòu)為例,這個(gè)單鏈表沒(méi)有專(zhuān)門(mén)的傀儡節(jié)點(diǎn)來(lái)充當(dāng)頭節(jié)點(diǎn),首個(gè)節(jié)點(diǎn)就定義為頭節(jié)點(diǎn),所以頭插法,就是我們定義一個(gè)節(jié)點(diǎn),插在這個(gè)鏈表的最前面,作為新的 head。

代碼實(shí)現(xiàn):

1.定義一個(gè)插入的節(jié)點(diǎn)

 ListNode cur = new ListNode(2);

在這里插入圖片描述

此時(shí)我們就創(chuàng)建了一個(gè)val 為2 的節(jié)點(diǎn)。

2.插在頭節(jié)點(diǎn)的前面

這里分兩種情況,

第一次插入節(jié)點(diǎn)

不是第一次插入節(jié)點(diǎn)

頭插之后的結(jié)構(gòu):

在這里插入圖片描述

代碼實(shí)現(xiàn):

在這里插入圖片描述

(3)尾插法

和頭插法類(lèi)似,同樣插入一個(gè)節(jié)點(diǎn),在鏈表的最后。

在這里插入圖片描述

這里插入也分為兩種情況

第一次插入節(jié)點(diǎn)

不是第一次插入節(jié)點(diǎn)

代碼實(shí)現(xiàn):

在這里插入圖片描述

(4)根據(jù)下標(biāo)插入節(jié)點(diǎn)

第一個(gè)數(shù)據(jù)節(jié)點(diǎn)為0號(hào)下標(biāo),任意位置插入節(jié)點(diǎn)。

還以上面的鏈表為例,我們想將新的節(jié)點(diǎn)插入到2 號(hào)位置

在這里插入圖片描述

如果想插到2號(hào)位置,我們需要改變?cè)瓉?lái)的 1號(hào)位置節(jié)點(diǎn)和2號(hào)位置節(jié)點(diǎn)的相關(guān)屬性。

思路實(shí)現(xiàn):

  1.先判斷傳入的 index 下標(biāo)位置是否合法

  2.如果傳入的index==0,頭插法

  3.如果傳入的index==sizeof(),尾插法

  4.如果 sizeof() > index > 0 在鏈表中間插入,我們首先要找到 index-1 位置的節(jié)點(diǎn) prev

查找 index-1

在這里插入圖片描述

修改 prev節(jié)點(diǎn)的屬性 以及 新節(jié)點(diǎn)的屬性

  node.next = prev.next
     prev.next = node;

代碼實(shí)現(xiàn)過(guò)程

在這里插入圖片描述

(5)查找關(guān)鍵字

在這里插入圖片描述

以上面的鏈表為例,我們現(xiàn)在要查找這個(gè)鏈表中是否出現(xiàn) val=20 的節(jié)點(diǎn),如果存在,那么返回true,如果不存在,則返回 false.

遍歷鏈表,走過(guò)每一個(gè)節(jié)點(diǎn),如果 cur.val == key,則 return ture ,遍歷完后還未找到 key,那么return false.

在這里插入圖片描述

(6)刪除第一次出現(xiàn)的關(guān)鍵字

在這里插入圖片描述

思路實(shí)現(xiàn):

在這里插入圖片描述

代碼實(shí)現(xiàn):

在這里插入圖片描述

(7)得到單鏈表的長(zhǎng)度

在這里插入圖片描述

(8)單鏈表打印展示

在這里插入圖片描述

不能是this.head.next != null 這樣寫(xiě) 最后一個(gè)節(jié)點(diǎn)是不能被打印的

(9)節(jié)點(diǎn)的回收

節(jié)點(diǎn)的回收有兩種方式:

  1.暴力法

直接將head 置空

  2. 挨個(gè)置空

遍歷單鏈表,將每一個(gè)節(jié)點(diǎn)的next都置為 null.

在這里插入圖片描述

四、完整代碼的展示

在這里插入圖片描述

到此這篇關(guān)于Java數(shù)據(jù)結(jié)構(gòu)之單鏈表詳解的文章就介紹到這了,更多相關(guān)Java單鏈表內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • WebSocket+Vue+SpringBoot實(shí)現(xiàn)語(yǔ)音通話的使用示例

    WebSocket+Vue+SpringBoot實(shí)現(xiàn)語(yǔ)音通話的使用示例

    本文主要介紹了WebSocket+Vue+SpringBoot實(shí)現(xiàn)語(yǔ)音通話的使用示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-11-11
  • 詳解SpringBoot Starter作用及原理

    詳解SpringBoot Starter作用及原理

    大家都知道基于 SpringBoot 開(kāi)發(fā)項(xiàng)目可以簡(jiǎn)化 Spring 應(yīng)用的搭建以及開(kāi)發(fā)過(guò)程,提高程序員開(kāi)發(fā)效率,這是由于其“約定大約配置”的策略及其自動(dòng)裝配的特點(diǎn),Starter 就是自動(dòng)裝配的具體實(shí)現(xiàn),本文詳細(xì)介紹了SpringBoot Starter作用及原理,歡迎大家來(lái)閱讀學(xué)習(xí)
    2023-04-04
  • Springboot異常日志輸出方式

    Springboot異常日志輸出方式

    這篇文章主要介紹了Springboot異常日志輸出方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • Java中的方法內(nèi)聯(lián)介紹

    Java中的方法內(nèi)聯(lián)介紹

    大家好,本篇文章主要講的是Java中的方法內(nèi)聯(lián)介紹,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下
    2022-01-01
  • java實(shí)現(xiàn)Z字形掃描程序

    java實(shí)現(xiàn)Z字形掃描程序

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)Z字形掃描程序,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-03-03
  • SpringBoot3安全管理操作方法

    SpringBoot3安全管理操作方法

    這篇文章主要介紹了SpringBoot3安全管理,在實(shí)際開(kāi)發(fā)中,最常用的是登錄驗(yàn)證和權(quán)限體系兩大功能,在登錄時(shí)完成身份的驗(yàn)證,加載相關(guān)信息和角色權(quán)限,在訪問(wèn)其他系統(tǒng)資源時(shí),進(jìn)行權(quán)限的驗(yàn)證,保護(hù)系統(tǒng)的安全,文中有詳細(xì)的操作步驟,需要的朋友可以參考下
    2023-08-08
  • Java 大小寫(xiě)最快轉(zhuǎn)換方式實(shí)例代碼

    Java 大小寫(xiě)最快轉(zhuǎn)換方式實(shí)例代碼

    這篇文章主要介紹了Java 大小寫(xiě)最快轉(zhuǎn)換方式實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下
    2017-07-07
  • 在Spring Boot中實(shí)現(xiàn)HTTP緩存的方法

    在Spring Boot中實(shí)現(xiàn)HTTP緩存的方法

    緩存是HTTP協(xié)議的一個(gè)強(qiáng)大功能,但由于某些原因,它主要用于靜態(tài)資源,如圖像,CSS樣式表或JavaScript文件。本文重點(diǎn)給大家介紹在Spring Boot中實(shí)現(xiàn)HTTP緩存的方法,感興趣的朋友跟隨小編一起看看吧
    2018-10-10
  • 深入學(xué)習(xí)Hibernate持久化對(duì)象的三個(gè)狀態(tài)

    深入學(xué)習(xí)Hibernate持久化對(duì)象的三個(gè)狀態(tài)

    Hibernate中的對(duì)象有3中狀態(tài),瞬時(shí)對(duì)象(TransientObjects)、持久化對(duì)象(PersistentObjects)和離線對(duì)象(DetachedObjects也叫做脫管對(duì)象),下面通過(guò)本文給大家分享Hibernate持久化對(duì)象的三個(gè)狀態(tài),一起看看吧
    2017-09-09
  • 永中文檔在線轉(zhuǎn)換服務(wù)Swagger調(diào)用說(shuō)明

    永中文檔在線轉(zhuǎn)換服務(wù)Swagger調(diào)用說(shuō)明

    這篇文章主要為大家介紹了永中文檔在線轉(zhuǎn)換服務(wù)Swagger調(diào)用說(shuō)明,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06

最新評(píng)論