PHP中數(shù)組和鏈表的區(qū)別
從邏輯結構來看
1.、數(shù)組必須事先定義固定的長度(元素個數(shù)),不能適應數(shù)據(jù)動態(tài)地增減的情況。當數(shù)據(jù)增加時,可能超出原先定義的元素個數(shù);當數(shù)據(jù)減少時,造成內存浪費;數(shù)組可以根據(jù)下標直接存取。
2、鏈表動態(tài)地進行存儲分配,可以適應數(shù)據(jù)動態(tài)地增減的情況,且可以方便地插入、刪除數(shù)據(jù)項。(數(shù)組中插入、刪除數(shù)據(jù)項時,需要移動其它數(shù)據(jù)項,非常繁瑣)鏈表必須根據(jù)next指針找到下一個元素。
從內存存儲來看
1、(靜態(tài))數(shù)組從棧中分配空間, 對于程序員方便快速,但是自由度小。
2、鏈表從堆中分配空間, 自由度大但是申請管理比較麻煩 。
從上面的比較可以看出,如果需要快速訪問數(shù)據(jù),很少或不插入和刪除元素,就應該用數(shù)組;相反, 如果需要經常插入和刪除元素就需要用鏈表數(shù)據(jù)結構了。
補充:
數(shù)組是將元素在內存中連續(xù)存放,由于每個元素占用內存相同,可以通過下標迅速訪問數(shù)組中任何元素。但是如果要在數(shù)組中增加一個元素,需要移動大量元素,在內存中空出一個元素的空間,然后將要增加的元素放在其中。
同樣的道理,如果想刪除一個元素,同樣需要移動大量元素去填掉被移動的元素。如果應用需要快速訪問數(shù)據(jù),很少或不插入和刪除元素,就應該用數(shù)組。
鏈表恰好相反,鏈表中的元素在內存中不是順序存儲的,而是通過存在元素中的指針聯(lián)系到一起。比如:上一個元素有個指針指到下一個元素,以此類推,直到最后一個元素。
如果要訪問鏈表中一個元素,需要從第一個元素開始,一直找到需要的元素位置。但是增加和刪除一個元素對于鏈表數(shù)據(jù)結構就非常簡單了,只要修改元素中的指針就可以了。如果應用需要經常插入和刪除元素你就需要用鏈表數(shù)據(jù)結構了。
以上就是本次介紹的全部知識點內容,感謝大家的閱讀和對腳本之家的支持。
您可能感興趣的文章:- Python實現(xiàn)隊列的方法示例小結【數(shù)組,鏈表】
- Python實現(xiàn)棧的方法詳解【基于數(shù)組和單鏈表兩種方法】
- JavaScript將數(shù)組轉換為鏈表的方法
- 使用python實現(xiàn)數(shù)組、鏈表、隊列、棧的方法
- java使用數(shù)組和鏈表實現(xiàn)隊列示例
- 兩路歸并的數(shù)組與鏈表的實現(xiàn)方法
- Redis數(shù)組和鏈表深入詳解