前言
推出一個新系列,《看圖輕鬆理解資料結構和演算法》,主要使用圖片來描述常見的資料結構和演算法,輕鬆閱讀並理解掌握。本系列包括各種堆、各種佇列、各種列表、各種樹、各種圖、各種排序等等幾十篇的樣子。
雙向連結串列
雙向連結串列屬於連結串列的一種,也叫雙連結串列雙向即是說它的連結方向是雙向的,它由若干個節點組成,每個節點都包含下一個節點和上一個節點的指標,所以從雙向連結串列的任意節點開始,都能很方便訪問他的前驅結點和後繼節點。
雙連結串列特點
- 建立雙連結串列時無需指定連結串列的長度。
- 比起單連結串列,雙連結串列需要多一個指標用於指向前驅節點,所以需要儲存空間比單連結串列多一點。
- 雙連結串列的插入和刪除需要同時維護 next 和 prev 兩個指標。
- 雙連結串列中的元素訪問需要通過順序訪問,即要通過遍歷的方式來尋找元素。
雙連結串列建立
建立一個空連結串列,
data:image/s3,"s3://crabby-images/70ab0/70ab0cd105ff5e7e2f82b87ffb2be415ddf36e25" alt="image"
插入鏈尾
將the monster is coming
這些單詞按順序分別插入尾部,建立“the”節點,
data:image/s3,"s3://crabby-images/560c2/560c26bba3c4db6a8ebdca5158129dd45d0a5bad" alt="image"
連線起來,
data:image/s3,"s3://crabby-images/f973b/f973b6cd7488525aec0974603f30c6205e50f5cb" alt="image"
建立“monster”節點,
data:image/s3,"s3://crabby-images/fa837/fa837be1c43e2c3495eb10dcb15c9a454f76636f" alt="image"
再連線起來,
data:image/s3,"s3://crabby-images/c42df/c42dfb69f5ac4021d722adc15bb73ded5875c037" alt="image"
以此類推,將剩下的節點全部建立並連線起來。
data:image/s3,"s3://crabby-images/0d0eb/0d0ebb2e0ed33c071c3c18628b9f6cb917e13276" alt="image"
data:image/s3,"s3://crabby-images/fa2b3/fa2b339b3642bc5504824c8b396eb4ca4608f858" alt="image"
建立迭代器
迭代器的 current 指標初始指向head,
data:image/s3,"s3://crabby-images/2a328/2a32801e5db63a9239144e52752890cd5ff2047d" alt="image"
執行兩次 next 操作, current 指標指向索引為2的節點,
data:image/s3,"s3://crabby-images/d4e32/d4e32c5a6f84f88303f9127048d4fae53a4db388" alt="image"
此時的節點值為,
data:image/s3,"s3://crabby-images/0e3a0/0e3a02b1ebd6aea44cf2612007c8959eba945d14" alt="image"
設定 current 指標指向索引為3的節點,
data:image/s3,"s3://crabby-images/20766/2076600e85cf7e270fde6c3513bf7026c7751b90" alt="image"
插入節點
在索引1後面插入“big”節點。先將 current 指標指向索引為1的節點,建立一個"big"新節點,
data:image/s3,"s3://crabby-images/02244/02244039e8a41cb467ecb7b75f72434f857ffcba" alt="image"
插入到 current 指向位置,
data:image/s3,"s3://crabby-images/0c67b/0c67b3d3eb136f10ef2d067bb377d761d4965070" alt="image"
刪除節點
將“big”節點刪除,移動當前指標 current 到“but”節點位置,
data:image/s3,"s3://crabby-images/2eb67/2eb6729a0b09bbdd6ca968816dbc7b352b242a06" alt="image"
執行刪除操作,斷掉“big”節點與前後兩節點的 next 和 prev 指標,然後將“the”節點與“monster”節點關聯起來,
data:image/s3,"s3://crabby-images/9ad8b/9ad8bb4821ccd66aecba262ed2ff35e80d44991d" alt="image"
data:image/s3,"s3://crabby-images/4bf51/4bf5194c3818fcd4d6bad925edfa1b1b25ea5238" alt="image"
雙向迴圈連結串列
前面的雙向連結串列的 head 節點和鏈尾沒有連線關係,所以如果要訪問最後一個節點的話需要從頭開始遍歷,直到最後一個節點。在雙向連結串列基礎上改進一下,把 header 節點的 prev 指標指向最後一個節點,而最後一個節點的 next 指標指向 header 節點,於是便構成雙向迴圈連結串列。
data:image/s3,"s3://crabby-images/76c58/76c58fc9901592f71e99b2efc983f875ed97d6c0" alt="image"
-------------推薦閱讀------------
我的開源專案彙總(機器&深度學習、NLP、網路IO、AIML、mysql協議、chatbot)
跟我交流,向我提問:
data:image/s3,"s3://crabby-images/0095c/0095c82d90317995cd268a1237d5b62a31810e20" alt="看圖輕鬆理解資料結構與演算法系列(雙向連結串列)"
歡迎關注:
data:image/s3,"s3://crabby-images/55def/55def51a71771ba0cb4483a5a6640b88d467808c" alt="看圖輕鬆理解資料結構與演算法系列(雙向連結串列)"