資料結構連結串列各種問題
一:連結串列原理
連結串列是一種資料結構,和陣列同級。比如,Java中我們使用的ArrayList,其實現原理是陣列。而LinkedList的實現原理就是連結串列了。連結串列在進行迴圈遍歷時效率不高,但是插入和刪除時優勢明顯。下面對單向連結串列做一個介紹。
單向連結串列是一種線性表,實際上是由節點(Node)組成的,一個連結串列擁有不定數量的節點。其資料在記憶體中儲存是不連續的,它儲存的資料分散在記憶體中,每個結點只能也只有它能知道下一個結點的儲存位置。由N各節點(Node)組成單向連結串列,每一個Node記錄本Node的資料及下一個Node。向外暴露的只有一個頭節點(Head),我們對連結串列的所有操作,都是直接或者間接地通過其頭節點來進行的。
上圖中最左邊的節點即為頭結點(Head),但是新增節點的順序是從右向左的,新增的新節點會被作為新節點。最先新增的節點對下一節點的引用可以為空。引用是引用下一個節點而非下一個節點的物件。因為有著不斷的引用,所以頭節點就可以操作所有節點了。
下圖描述了單向連結串列儲存情況。儲存是分散的,每一個節點只要記錄下一節點,就把所有資料串了起來,形成了一個單向連結串列。
節點(Node)是由一個需要儲存的物件及對下一個節點的引用組成的。也就是說,節點擁有兩個成員:儲存的物件、對下一個節點的引用。下面圖是具體的說明:
二、連結串列的實現
三、連結串列相關的常見面試題總結
1. 連結串列反轉
調整指標的指向,反轉後連結串列的頭結點是原始連結串列的尾節點。
執行結果:
2. 查詢單連結串列的中間節點
採用快慢指標的方式查詢單連結串列的中間節點,快指標一次走兩步,慢指標一次走一步,當快指標走完時,慢指標剛好到達中間節點。
3.查詢倒數第k個元素
採用兩個指標P1,P2,P1先前移K步,然後P1、P2同時移動,當p1移動到尾部時,P2所指位置的元素即倒數第k個元素 。
4. 對連結串列進行排序
執行結果:
5. 刪除連結串列中的重複節點
6. 從尾到頭輸出單連結串列,採用遞迴方式實現
7. 判斷連結串列是否有環,有環情況下找出環的入口節點
相關文章
- 資料結構連結串列筆試題資料結構筆試
- 資料結構-單連結串列、雙連結串列資料結構
- 資料結構 - 連結串列資料結構
- 連結串列-資料結構資料結構
- 資料結構—連結串列資料結構
- 資料結構--連結串列資料結構
- 資料結構-連結串列資料結構
- 資料結構與演算法——連結串列 Linked List(單連結串列、雙向連結串列、單向環形連結串列-Josephu 問題)資料結構演算法
- 資料結構之連結串列資料結構
- 資料結構之「連結串列」資料結構
- JavaScript資料結構--連結串列JavaScript資料結構
- 資料結構之連結串列:206. 反轉連結串列資料結構
- 資料結構:跳躍連結串列資料結構
- 資料結構——雙向連結串列資料結構
- 資料結構之單連結串列資料結構
- 資料結構之連結串列操作資料結構
- JAVA資料結構之連結串列Java資料結構
- 資料結構04——單連結串列資料結構
- JavaScript資料結構 之 連結串列JavaScript資料結構
- js資料結構--連結串列(likedList)JS資料結構
- 資料結構基礎 連結串列資料結構
- Java版-資料結構-連結串列Java資料結構
- 資料結構學習--連結串列資料結構
- 資料結構之連結串列【上】資料結構
- JS資料結構(四)——連結串列JS資料結構
- 前端資料結構--線性結構-連結串列前端資料結構
- 資料結構實驗之連結串列二:逆序建立連結串列資料結構
- 資料結構實驗之連結串列九:雙向連結串列資料結構
- 資料結構--陣列、單向連結串列、雙向連結串列資料結構陣列
- 單連結串列建立連結串列出現問題
- Redis資料結構—連結串列與字典的結構Redis資料結構
- JS資料結構第三篇---雙向連結串列和迴圈連結串列之約瑟夫問題JS資料結構
- 資料結構-線性表、連結串列資料結構
- Redis資料結構—連結串列與字典Redis資料結構
- 資料結構之迴圈連結串列資料結構
- 資料結構之雙向連結串列資料結構
- 【資料結構】連結串列(單連結串列實現+詳解+原碼)資料結構
- 資料結構實驗之連結串列三:連結串列的逆置資料結構
- 資料結構實驗之連結串列五:單連結串列的拆分資料結構