定義:
表由一系列結(jié)點(diǎn)(鏈表中每一個(gè)元素稱(chēng)為結(jié)點(diǎn))組成袜腥,結(jié)點(diǎn)可以在運(yùn)行時(shí)動(dòng)態(tài)生成舷夺。每個(gè)結(jié)點(diǎn)包括兩個(gè)部分:一個(gè)是存儲(chǔ)數(shù)據(jù)元素的數(shù)據(jù)域,另一個(gè)是存儲(chǔ)下一個(gè)結(jié)點(diǎn)地址的指針域。 相比于線性表順序結(jié)構(gòu)岔帽,操作復(fù)雜昵仅。由于不必須按順序存儲(chǔ),鏈表在插入的時(shí)候可以達(dá)到O(1)的復(fù)雜度梢卸,比另一種線性表順序表快得多走诞,但是查找一個(gè)節(jié)點(diǎn)或者訪問(wèn)特定編號(hào)的節(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)的指針域,空間開(kāi)銷(xiāo)比較大恤批。鏈表最明顯的好處就是异吻,常規(guī)數(shù)組排列關(guān)聯(lián)項(xiàng)目的方式可能不同于這些數(shù)據(jù)項(xiàng)目在記憶體或磁盤(pán)上順序,數(shù)據(jù)的存取往往要在不同的排列順序中轉(zhuǎn)換喜庞。鏈表允許插入和移除表上任意位置上的節(jié)點(diǎn)诀浪,但是不允許隨機(jī)存取。鏈表有很多種不同的類(lèi)型:?jiǎn)蜗蜴湵硌佣迹p向鏈表以及循環(huán)鏈表雷猪。鏈表可以在多種編程語(yǔ)言中實(shí)現(xiàn)。像Lisp和Scheme這樣的語(yǔ)言的內(nèi)建數(shù)據(jù)類(lèi)型中就包含了鏈表的存取和操作窄潭。程序語(yǔ)言或面向?qū)ο笳Z(yǔ)言春宣,如C,C++和Java依靠易變工具來(lái)生成鏈表。
初步實(shí)現(xiàn)簡(jiǎn)單鏈表的具體步驟如下:
第一嫉你,創(chuàng)建出節(jié)點(diǎn)月帝、初始化鏈表,將內(nèi)存創(chuàng)造出來(lái)和清空鏈表幽污。
第二步距误,添加節(jié)點(diǎn)簸搞。
第三步趁俊,獲取某個(gè)節(jié)點(diǎn)中的元素(數(shù)據(jù))和遍歷鏈表中的元素(數(shù)據(jù))域仇。
第四步垦细,調(diào)用方法。
以上這個(gè)鏈表相對(duì)比較容易挡逼,重點(diǎn)是在第一步:創(chuàng)建出節(jié)點(diǎn)括改、初始化鏈表,將內(nèi)存創(chuàng)造出來(lái)和清空鏈表家坎。