算法与数据结构--数组和链表的区别
生活随笔
收集整理的這篇文章主要介紹了
算法与数据结构--数组和链表的区别
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
最近由于在找工作,經(jīng)歷了一些校招面試后,感覺在數(shù)據(jù)結(jié)構(gòu)和操作系統(tǒng)上面,還有很多的欠缺。所以今天要學(xué)習(xí)一下數(shù)據(jù)結(jié)構(gòu)。還是從面試的那到題開始。
數(shù)組和鏈表的區(qū)別?
C和C++語言中用數(shù)組處理一組數(shù)據(jù)類型相同的數(shù)據(jù),但不允許動(dòng)態(tài)定義數(shù)組的大小,即在使用數(shù)組之前必須確定數(shù)組的大小。而在實(shí)際應(yīng)用中,用戶使用數(shù)組之前有時(shí)無法準(zhǔn)確確定數(shù)組的大小,只能將數(shù)組定義成足夠大小,這樣數(shù)組中有些空間可能不被使用,從而造成內(nèi)存空間的浪費(fèi)。鏈表是一種常見的數(shù)據(jù)組織形式。它采用動(dòng)態(tài)分配內(nèi)存的形式實(shí)現(xiàn)。需要是可以用new分配內(nèi)存空間,不需要時(shí)用delete將已分配的空間釋放,不會(huì)造成內(nèi)存空間的浪費(fèi)。 從邏輯結(jié)構(gòu)來看:數(shù)組必須事先定義固定的長(zhǎng)度(元素個(gè)人),不能適應(yīng)數(shù)據(jù)動(dòng)態(tài)地增減的情況,即數(shù)組的大小一旦定義就不能改變。當(dāng)數(shù)據(jù)增加時(shí),可能超出原先定義的元素個(gè)數(shù);當(dāng)數(shù)據(jù)減少時(shí),造成內(nèi)存浪費(fèi);鏈表動(dòng)態(tài)地進(jìn)行存儲(chǔ)分配,可以適應(yīng)數(shù)據(jù)動(dòng)態(tài)地增減的情況,且可以方便地插入、刪除除數(shù)據(jù)項(xiàng)。(數(shù)組中插入、刪除數(shù)據(jù)項(xiàng)時(shí),需要移動(dòng)其他數(shù)據(jù)項(xiàng))。 從內(nèi)存存儲(chǔ)來看:(靜態(tài)數(shù)組)數(shù)組從棧中分配空間(用new創(chuàng)建的在堆中),對(duì)于程序員方便快速,但是自由度小;鏈表從堆中分配空間,自由度大但是申請(qǐng)管理比較麻煩。 從訪問方式來看:數(shù)組在內(nèi)存中是連續(xù)存儲(chǔ)的,因此,可以利用下標(biāo)索引進(jìn)行隨機(jī)訪問;鏈表是鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu),在訪問元素的時(shí)候只能通過線性方式由前到后順序訪問,所以訪問效率比數(shù)組要低。轉(zhuǎn)載于:https://www.cnblogs.com/luzuoquan/p/3593568.html
總結(jié)
以上是生活随笔為你收集整理的算法与数据结构--数组和链表的区别的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: poj 1015 Jury Compro
- 下一篇: 设计模式介绍