數組與鏈表的區別?


數組與鏈表的區別?


數組

  • Java基於數組實現的集合
    ArrayList
  • 數組示意圖
    enter description here
  • 數組特性舉例

數組就像身上編了號站成一排的人,要找第10個人很容易,根據人身上的編號很快就能找到。但插入、刪除慢,要望某個位置插入或刪除一個人時,后面的人身上的編號都要變。當然,加入或刪除的人始終末尾的也快


鏈表

  • Java基於鏈表實現的集合
    LinkedList
  • 鏈表示意圖
    enter description here
  • 鏈表特性舉例

鏈表就像手牽着手站成一圈的人,要找第10個人不容易,必須從第一個人一個個數過去。但插入、刪除快。插入時只要解開兩個人的手,並重新牽上新加進來的人的手就可以。刪除一樣的道理


數組和鏈表對比

分類 數組 鏈表
邏輯結構角度 數組必須事先定義固定的長度(元素個數),不能適應數據動態地增減的情況。當數據增加時,可能超出原先定義的元素個數;當數據減少時,造成內存浪費 鏈表動態地進行存儲分配,可以適應數據動態地增減的情況,且可以方便地插入、刪除數據項。(數組中插入、刪除數據項時,需要移動其它數據項)
內存存儲角度 (靜態)數組從棧中分配空間, 對於程序員方便快速,但自由度小 鏈表從堆中分配空間, 自由度大但申請管理比較麻煩

數組鏈表對比總結

  • 數組靜態分配內存,鏈表動態分配內存;

  • 數組在內存中連續,鏈表不連續;

  • 數組元素在棧區,鏈表元素在堆區;

  • 數組利用下標定位,時間復雜度為O(1),鏈表定位元素時間復雜度O(n);

  • 數組插入或刪除元素的時間復雜度O(n),鏈表的時間復雜度O(1);


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM