原文連接:http://blog.csdn.net/wangshihui512/article/details/9787699
程序員
數組:
數組
數組是將元素在內存中連續存放,因爲每一個元素佔用內存相同,能夠經過下標迅速訪問數組中任何元素。可是若是要在數組中增長一個元素,須要移動大量元素,在內存中空出一個元素的空間,而後將要增長的元素放在其中。一樣的道理,若是想刪除一個元素,一樣須要移動大量元素去填掉被移動的元素。若是應用須要快速訪問數據,不多或不插入和刪除元素,就應該用數組。數據結構
鏈表:C++語言中能夠用數組處理一組數據類型相同的數據,但不容許動態定義數組的大小,即在使用數組以前必須肯定數組的大小。而在實際應用中,用戶使用數組以前有時沒法準確肯定數組的大小,只能將數組定義成足夠大小,這樣數組中有些空間可能不被使用,從而形成內存空間的浪費。鏈表是一種常見的數據組織形式,它採用動態分配內存的形式實現。須要時能夠用new分配內存空間,不須要時用delete將已分配的空間釋放,不會形成內存空間的浪費。ide
(1) 從邏輯結構角度來看 b, 鏈表從堆中分配空間, 自由度大但申請管理比較麻煩.
ui
數組和鏈表的區別整理以下:
數組靜態分配內存,鏈表動態分配內存;
數組在內存中連續,鏈表不連續;
數組元素在棧區,鏈表元素在堆區;
數組利用下標定位,時間複雜度爲O(1),鏈表定位元素時間複雜度O(n);
數組插入或刪除元素的時間複雜度O(n),鏈表的時間複雜度O(1)。 spa