Java數(shù)據(jù)結(jié)構(gòu)之鏈表的概念及結(jié)構(gòu)
1、鏈表的概念
概念:鏈表是一種物理存儲結(jié)構(gòu)上非連續(xù)、非順序的存儲結(jié)構(gòu),數(shù)據(jù)元素的邏輯順序是通過鏈表中的指針鏈接次序?qū)崿F(xiàn)的
1、鏈表由一系列結(jié)點(diǎn)(鏈表中每一個元素稱為結(jié)點(diǎn))組成。
2、結(jié)點(diǎn)可以在運(yùn)行時動態(tài)(malloc)生成。
3、每個結(jié)點(diǎn)包括兩個部分:一個是存儲數(shù)據(jù)元素的數(shù)據(jù)域,另一個是存儲下一個結(jié)點(diǎn)地址的指針域(詳見1.2 節(jié)點(diǎn)部分)。
4、相比于線性表順序結(jié)構(gòu),鏈表操作復(fù)雜。但是由于不需按順序存儲,鏈表在插入的時候可以達(dá)到O(1)的復(fù)雜度,比順序表快得多;但是查找一個節(jié)點(diǎn)或者訪問特定編號的節(jié)點(diǎn)則需要O(n)的時間,而順序表只需O(1)
2、結(jié)點(diǎn)
鏈表由一個個結(jié)點(diǎn)構(gòu)成,每個結(jié)點(diǎn)采用結(jié)構(gòu)體的形式。結(jié)構(gòu)體內(nèi)前面的變量按照需要給予,最后一個變量是這個結(jié)構(gòu)體類型的指針,用來存放下一節(jié)點(diǎn)的首地址‘
鏈表結(jié)點(diǎn)分為兩個域
數(shù)據(jù)域 :存放各種實(shí)際的數(shù)據(jù)
指針域 :存放下一結(jié)點(diǎn)的地址

(圖為帶哨兵位頭結(jié)點(diǎn)的鏈表)
3、鏈表的使用場景
線性表在 需要經(jīng)常插入或刪除數(shù)據(jù)元素 的情況下適合采用鏈?zhǔn)酱鎯Y(jié)構(gòu)。
因?yàn)閷τ阪湵韥碚f,插入或刪除數(shù)據(jù)只需要創(chuàng)建一個結(jié)點(diǎn)、輸入數(shù)據(jù)、修改指針把該結(jié)點(diǎn)連接到鏈表中的某一位置即可; 而對于順序表,插入一個數(shù)據(jù)可能需要搬移其他數(shù)據(jù),復(fù)雜度高。
4、鏈表分類和常用結(jié)構(gòu)


雖然組合起來一共有8種鏈表可以選擇,但是實(shí)際中最常用的主要還是 無頭單向非循環(huán) 鏈表和 帶頭雙向循環(huán) 鏈表。
1、無頭單向非循環(huán)鏈表:俗稱 “單鏈表”。結(jié)構(gòu)簡單,一般不會單獨(dú)用來存儲數(shù)據(jù)。實(shí)際上更多是作為其他數(shù)據(jù)結(jié)構(gòu)的子結(jié)構(gòu)(如哈希桶、圖的鄰接表、棧的鏈?zhǔn)浇Y(jié)構(gòu)等)
2、帶頭雙向循環(huán)鏈表:結(jié)構(gòu)最復(fù)雜,一般用來單獨(dú)存儲數(shù)據(jù)。實(shí)際使用的鏈表,大多都是帶頭雙向循環(huán)鏈表。雖然結(jié)構(gòu)最復(fù)雜,但是這種結(jié)構(gòu)會帶來很多優(yōu)勢。
5、與順序表的比較
鏈表: 鏈表是通過結(jié)點(diǎn)把離散的數(shù)據(jù)鏈接成一個表,通過對結(jié)點(diǎn)的插入、刪除操作從而實(shí)現(xiàn)對數(shù)據(jù)的存取。
順序表: 順序表是通過開辟一段連續(xù)的內(nèi)存(直接使用 數(shù)組 或者 malloc后realloc擴(kuò)容)來存儲數(shù)據(jù)。
但是由于 realloc 擴(kuò)容分為原地擴(kuò)容和異地擴(kuò)容,前者代價較低,而后者擴(kuò)容時不僅需要拷貝數(shù)據(jù),還要釋放舊空間。再者,擴(kuò)容時一般會擴(kuò)到原來容量的2倍,擴(kuò)容次數(shù)多了就容易造成空間的浪費(fèi)
順序表的每個成員對應(yīng)鏈表的結(jié)點(diǎn);成員和結(jié)點(diǎn)的數(shù)據(jù)類型可以是標(biāo)準(zhǔn)的c類型或者是用戶自定義的結(jié)構(gòu)體類型。
| 比較對象 | 順序表 | 鏈表 |
|---|---|---|
| 存儲空間 | 連續(xù) | 不連續(xù) |
| 插入或刪除數(shù)據(jù) | 可能要搬移數(shù)據(jù),復(fù)雜度O(n) | 只需修改指針 |
| push | 動態(tài)順序表:空間不夠了需要擴(kuò)容 | 沒有“容量”的概念,push時直接malloc新的結(jié)點(diǎn) |
| 應(yīng)用 | 需要頻繁訪問 | 需要頻繁插入、刪除數(shù)據(jù) |
到此這篇關(guān)于Java數(shù)據(jù)結(jié)構(gòu)之鏈表的概念及結(jié)構(gòu)的文章就介紹到這了,更多相關(guān)Java 鏈表的概念結(jié)構(gòu)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Java鏈表數(shù)據(jù)結(jié)構(gòu)及其簡單使用方法解析
- Java 數(shù)據(jù)結(jié)構(gòu)之刪除鏈表中重復(fù)的結(jié)點(diǎn)
- Java數(shù)據(jù)結(jié)構(gòu)之簡單鏈表的定義與實(shí)現(xiàn)方法示例
- 詳解java數(shù)據(jù)結(jié)構(gòu)與算法之雙鏈表設(shè)計與實(shí)現(xiàn)
- java 數(shù)據(jù)結(jié)構(gòu)之刪除鏈表中的元素實(shí)例代碼
- Java模擬單鏈表和雙端鏈表數(shù)據(jù)結(jié)構(gòu)的實(shí)例講解
- java數(shù)據(jù)結(jié)構(gòu)之實(shí)現(xiàn)雙向鏈表的示例
- java實(shí)現(xiàn)數(shù)據(jù)結(jié)構(gòu)單鏈表示例(java單鏈表)
相關(guān)文章
教你創(chuàng)建springcloud微服務(wù)的基礎(chǔ)子服務(wù)的超詳細(xì)過程
這篇文章主要介紹了創(chuàng)建springcloud微服務(wù)的基礎(chǔ)子服務(wù),主要是創(chuàng)建兩個springboot服務(wù),在教程中增加springcloud相關(guān)組件,本文分步驟給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-04-04
java語言描述Redis分布式鎖的正確實(shí)現(xiàn)方式
這篇文章主要介紹了java語言描述Redis分布式鎖的正確實(shí)現(xiàn)方式,具有一定借鑒價值,需要的朋友可以參考下。2017-12-12
Aop動態(tài)代理和cglib實(shí)現(xiàn)代碼詳解
這篇文章主要介紹了Aop動態(tài)代理和cglib實(shí)現(xiàn)代碼詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-12-12
Spring+Quartz配置定時任務(wù)實(shí)現(xiàn)代碼
這篇文章主要介紹了Spring+Quartz配置定時任務(wù)實(shí)現(xiàn)代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-04-04
Java list與set中contains()方法效率案例詳解
這篇文章主要介紹了Java list與set中contains()方法效率案例詳解,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08
Java中的List和MySQL中的varchar相互轉(zhuǎn)換的解決方案
實(shí)體類中有一個 List<String> 類型的屬性,對應(yīng)于 MySQL 表里的 varchar 字段,使用 MyBatis 添加或查詢時能互相轉(zhuǎn)換,本文給大家介紹Java中的List和MySQL中的varchar相互轉(zhuǎn)換的解決方案,需要的朋友可以參考下2024-06-06

