不带头结点的链表基础操作(初始化,增删改查)
鏈表是什么?
**鏈表是一種物理存儲單元上非連續(xù)、非順序的存儲結(jié)構(gòu),數(shù)據(jù)元素的邏輯順序是通過鏈表中的指針鏈接次序?qū)崿F(xiàn)的。鏈表由一系列結(jié)點(diǎn)(鏈表中每一個(gè)元素稱為結(jié)點(diǎn))組成,結(jié)點(diǎn)可以在運(yùn)行時(shí)動(dòng)態(tài)生成。每個(gè)結(jié)點(diǎn)包括兩個(gè)部分:一個(gè)是存儲數(shù)據(jù)元素的數(shù)據(jù)域,另一個(gè)是存儲下一個(gè)結(jié)點(diǎn)地址的指針域。 相比于線性表順序結(jié)構(gòu),操作復(fù)雜。由于不必須按順序存儲,鏈表在插入的時(shí)候可以達(dá)到O(1)的復(fù)雜度,比另一種線性表順序表快得多,但是查找一個(gè)節(jié)點(diǎn)或者訪問特定編號的節(jié)點(diǎn)則需要O(n)的時(shí)間,而線性表和順序表相應(yīng)的時(shí)間復(fù)雜度分別是O(logn)和O(1)。
使用鏈表結(jié)構(gòu)可以克服數(shù)組鏈表需要預(yù)先知道數(shù)據(jù)大小的缺點(diǎn),鏈表結(jié)構(gòu)可以充分利用計(jì)算機(jī)內(nèi)存空間,實(shí)現(xiàn)靈活的內(nèi)存動(dòng)態(tài)管理。但是鏈表失去了數(shù)組隨機(jī)讀取的優(yōu)點(diǎn),同時(shí)鏈表由于增加了結(jié)點(diǎn)的指針域,空間開銷比較大。鏈表最明顯的好處就是,常規(guī)數(shù)組排列關(guān)聯(lián)項(xiàng)目的方式可能不同于這些數(shù)據(jù)項(xiàng)目在記憶體或磁盤上順序,數(shù)據(jù)的存取往往要在不同的排列順序中轉(zhuǎn)換。鏈表允許插入和移除表上任意位置上的節(jié)點(diǎn),但是不允許隨機(jī)存取。鏈表有很多種不同的類型:單向鏈表,雙向鏈表以及循環(huán)鏈表。鏈表可以在多種編程語言中實(shí)現(xiàn)。像Lisp和Scheme這樣的語言的內(nèi)建數(shù)據(jù)類型中就包含了鏈表的存取和操作。程序語言或面向?qū)ο笳Z言,如C,C++和Java依靠易變工具來生成鏈表。**
鏈表基礎(chǔ)操作
首先我們要想,一個(gè)結(jié)點(diǎn)里面要有什么?
一個(gè)是數(shù)據(jù)域,第二個(gè)是指針域,指向下一個(gè)結(jié)點(diǎn),所以我們用一個(gè)結(jié)構(gòu)體來包括一個(gè)結(jié)點(diǎn)所需要的這些內(nèi)容。
這是鏈表中的一個(gè)結(jié)點(diǎn)的內(nèi)容
SListDataType這個(gè)類型,是用戶自定義類型,可以是int ,double,char,還可以是一個(gè)結(jié)構(gòu)體類型。
而這個(gè)結(jié)構(gòu)體里,就是鏈表的創(chuàng)建,里面是第一個(gè)結(jié)點(diǎn)的指針。
初始化,首先傳一個(gè)鏈表的結(jié)構(gòu)體指針,第一步判斷指針是否為空,此處用斷言判斷,第二步初始化,給第一結(jié)點(diǎn)指空。
頭插,時(shí)間復(fù)雜度為O(1),傳進(jìn)來連邊的結(jié)構(gòu)體指針,和要給結(jié)點(diǎn)里附的值。
尾插,有循環(huán),O(n)
頭刪
尾刪 O(n)
查找
刪除多個(gè)值相同的結(jié)點(diǎn)
總結(jié)
以上是生活随笔為你收集整理的不带头结点的链表基础操作(初始化,增删改查)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 青春舞台剧情介绍
- 下一篇: golang有限制运行内存大小吗