陣列和鍊錶的區別

2022-07-06 01:15:09 字數 407 閱讀 2419

1.陣列的元素是固定的、連續的,在定義時分配儲存單元

有可能浪費空間或者下標越界需要重新定義陣列,空間效率差;

2.鍊錶的結點個數可按需要增減,可存在任何地方、不要求連續,在程式執行時動態向程式申請儲存單元。

1.陣列中的元素順序由元素在陣列中的位置下標確定;

2.鍊錶的結點順序有結點所包含的指標體現

鍊錶中每乙個資料都儲存這下乙個陣列的記憶體位址,故鍊錶的結構為兩部分組成:第一部分是鍊錶的資料區域data,第二部分是後繼結點的指標域next

。1.陣列查詢快

陣列插入需要將插入位置後面的所有資料後移,因此插入效率極低,刪除同理;

2.鍊錶插入、刪除快

鍊錶查詢需要從第乙個資料開始遍歷,由第乙個資料儲存的指標查詢第二個資料,以此類推,因此查詢效率極低

陣列和鍊錶區別

談到鍊錶與陣列的區別,可以從幾個不同的角度來談,首先從邏輯結構上說,兩者都是資料結構的一種,但存在區別,陣列是申請的一塊連續的記憶體空間,並且是在編譯階段就要確定空間大小的,同時在執行階段是不允許改變的,所以它不能夠隨著需要的改變而增加或減少空間大小,所以當資料量大的時候,有可能超出了已申請好的陣列...

陣列和鍊錶的區別

陣列與鍊錶的區別 1.基於空間的考慮 陣列的儲存空間是靜態,連續分布的,估計過大造成空間浪費,估計太小又將使空間溢位機會增多。而鍊錶的儲存空間是動態分布的,只要記憶體空間尚有空閒,就不會產生溢位 鍊錶中每個節點除了資料域外,還有指標域,儲存密度小於1 陣列為 儲存空間利用率就越高。2.基於時間的考慮...

陣列和鍊錶的區別

1 陣列的儲存空間是一大片連續的,鍊錶的儲存空間是不定的,每個鍊錶的節點元素都會儲存該節點的資料和下個節點的位址指向。陣列初使化必須制定大小,而鍊錶卻不需要便是這個原因。2 就增刪改查而言,陣列因為位址是連續的,所以陣列的查詢修改很快,但是增刪的時候由於需要移動後面所有的元素反而較慢,對應的鍊錶在查...