Java數(shù)據(jù)結(jié)構(gòu)之鏈表的概念及結(jié)構(gòu)
1、鏈表的概念
概念:鏈表是一種物理存儲(chǔ)結(jié)構(gòu)上非連續(xù)、非順序的存儲(chǔ)結(jié)構(gòu),數(shù)據(jù)元素的邏輯順序是通過鏈表中的指針鏈接次序?qū)崿F(xiàn)的
1、鏈表由一系列結(jié)點(diǎn)(鏈表中每一個(gè)元素稱為結(jié)點(diǎn))組成。
2、結(jié)點(diǎn)可以在運(yùn)行時(shí)動(dòng)態(tài)(malloc)生成。
3、每個(gè)結(jié)點(diǎn)包括兩個(gè)部分:一個(gè)是存儲(chǔ)數(shù)據(jù)元素的數(shù)據(jù)域,另一個(gè)是存儲(chǔ)下一個(gè)結(jié)點(diǎn)地址的指針域(詳見1.2 節(jié)點(diǎn)部分)。
4、相比于線性表順序結(jié)構(gòu),鏈表操作復(fù)雜。但是由于不需按順序存儲(chǔ),鏈表在插入的時(shí)候可以達(dá)到O(1)的復(fù)雜度,比順序表快得多;但是查找一個(gè)節(jié)點(diǎn)或者訪問特定編號(hào)的節(jié)點(diǎn)則需要O(n)的時(shí)間,而順序表只需O(1)
2、結(jié)點(diǎn)
鏈表由一個(gè)個(gè)結(jié)點(diǎn)構(gòu)成,每個(gè)結(jié)點(diǎn)采用結(jié)構(gòu)體的形式。結(jié)構(gòu)體內(nèi)前面的變量按照需要給予,最后一個(gè)變量是這個(gè)結(jié)構(gòu)體類型的指針,用來存放下一節(jié)點(diǎn)的首地址‘
鏈表結(jié)點(diǎn)分為兩個(gè)域
數(shù)據(jù)域 :存放各種實(shí)際的數(shù)據(jù)
指針域 :存放下一結(jié)點(diǎn)的地址
(圖為帶哨兵位頭結(jié)點(diǎn)的鏈表)
3、鏈表的使用場景
線性表在 需要經(jīng)常插入或刪除數(shù)據(jù)元素 的情況下適合采用鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)。
因?yàn)閷τ阪湵韥碚f,插入或刪除數(shù)據(jù)只需要?jiǎng)?chuàng)建一個(gè)結(jié)點(diǎn)、輸入數(shù)據(jù)、修改指針把該結(jié)點(diǎn)連接到鏈表中的某一位置即可; 而對于順序表,插入一個(gè)數(shù)據(jù)可能需要搬移其他數(shù)據(jù),復(fù)雜度高。
4、鏈表分類和常用結(jié)構(gòu)
雖然組合起來一共有8種鏈表可以選擇,但是實(shí)際中最常用的主要還是 無頭單向非循環(huán) 鏈表和 帶頭雙向循環(huán) 鏈表。
1、無頭單向非循環(huán)鏈表:俗稱 “單鏈表”。結(jié)構(gòu)簡單,一般不會(huì)單獨(dú)用來存儲(chǔ)數(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ú)存儲(chǔ)數(shù)據(jù)。實(shí)際使用的鏈表,大多都是帶頭雙向循環(huán)鏈表。雖然結(jié)構(gòu)最復(fù)雜,但是這種結(jié)構(gòu)會(huì)帶來很多優(yōu)勢。
5、與順序表的比較
鏈表: 鏈表是通過結(jié)點(diǎn)把離散的數(shù)據(jù)鏈接成一個(gè)表,通過對結(jié)點(diǎn)的插入、刪除操作從而實(shí)現(xiàn)對數(shù)據(jù)的存取。
順序表: 順序表是通過開辟一段連續(xù)的內(nèi)存(直接使用 數(shù)組 或者 malloc后realloc擴(kuò)容)來存儲(chǔ)數(shù)據(jù)。
但是由于 realloc 擴(kuò)容分為原地?cái)U(kuò)容和異地?cái)U(kuò)容,前者代價(jià)較低,而后者擴(kuò)容時(shí)不僅需要拷貝數(shù)據(jù),還要釋放舊空間。再者,擴(kuò)容時(shí)一般會(huì)擴(kuò)到原來容量的2倍,擴(kuò)容次數(shù)多了就容易造成空間的浪費(fèi)
順序表的每個(gè)成員對應(yīng)鏈表的結(jié)點(diǎn);成員和結(jié)點(diǎn)的數(shù)據(jù)類型可以是標(biāo)準(zhǔn)的c類型或者是用戶自定義的結(jié)構(gòu)體類型。
比較對象 | 順序表 | 鏈表 |
---|---|---|
存儲(chǔ)空間 | 連續(xù) | 不連續(xù) |
插入或刪除數(shù)據(jù) | 可能要搬移數(shù)據(jù),復(fù)雜度O(n) | 只需修改指針 |
push | 動(dòng)態(tài)順序表:空間不夠了需要擴(kuò)容 | 沒有“容量”的概念,push時(shí)直接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è)計(jì)與實(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)文章
Java網(wǎng)絡(luò)編程UDP協(xié)議發(fā)送接收數(shù)據(jù)
這篇文章主要為大家詳細(xì)介紹了Java網(wǎng)絡(luò)編程UDP協(xié)議發(fā)送接收數(shù)據(jù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08java設(shè)計(jì)模式之建造者模式學(xué)習(xí)
建造者模式(Builder Pattern)主要用于“分步驟構(gòu)建一個(gè)復(fù)雜的對象”,在這其中“分步驟”是一個(gè)穩(wěn)定的算法,下面給出了詳細(xì)的示例2014-01-01SpringBoot實(shí)現(xiàn)動(dòng)態(tài)控制定時(shí)任務(wù)支持多參數(shù)功能
這篇文章主要介紹了SpringBoot實(shí)現(xiàn)動(dòng)態(tài)控制定時(shí)任務(wù)-支持多參數(shù)功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-05-05SpringBoot實(shí)現(xiàn)單點(diǎn)登錄的實(shí)現(xiàn)詳解
在現(xiàn)代的Web應(yīng)用程序中,單點(diǎn)登錄(Single?Sign-On)已經(jīng)變得越來越流行,在本文中,我們將使用Spring?Boot構(gòu)建一個(gè)基本的單點(diǎn)登錄系統(tǒng),需要的可以參考一下2023-05-05Mybatis 中的sql批量修改方法實(shí)現(xiàn)
在項(xiàng)目中遇到需要批量更新的功能,原本想的是在Java中用循環(huán)訪問數(shù)據(jù)庫去更新,但是心里總覺得這樣做會(huì)不會(huì)太頻繁了,太耗費(fèi)資源了,效率也很低,查了下mybatis的批量操作,原來確實(shí)有<foreach>標(biāo)簽可以做到,下面通過本文給大家介紹下2017-01-01Java8函數(shù)式接口的基礎(chǔ)學(xué)習(xí)教程
這篇文章主要給大家介紹了關(guān)于Java8函數(shù)式接口基礎(chǔ)學(xué)習(xí)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04