


版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、數(shù)據(jù)結(jié)構(gòu)和算法作者:小甲魚(yú)讓編程改變世界Change the world by program單鏈表的整表刪除當(dāng)我們不打算使用這個(gè)單鏈表時(shí),我們需要把它銷(xiāo)毀(真狠,不要就給別人嘛,還銷(xiāo)毀)。其實(shí)也就是在內(nèi)存中將它釋放掉,以便于留出空間給其他程序或軟件使用。單鏈表整表刪除的算法思路如下:聲明結(jié)點(diǎn)p和q;將第一個(gè)結(jié)點(diǎn)賦值給p,下一結(jié)點(diǎn)賦值給q;循環(huán)執(zhí)行釋放p和將q賦值給p的操作;單鏈表的整表刪除我們說(shuō)好的代碼呢?ClearList.c單鏈表的整表刪除這段算法代碼里,常見(jiàn)的錯(cuò)誤就是有同學(xué)會(huì)覺(jué)得q變量沒(méi)有存在的必要,只需要在循環(huán)體內(nèi)直接寫(xiě)free(p); p = p-next; 即可?可這個(gè)世上沒(méi)有無(wú)
2、緣無(wú)故的愛(ài),這樣做會(huì)帶來(lái)什么問(wèn)題呢?要知道p是一個(gè)結(jié)點(diǎn),它除了有數(shù)據(jù)域,還有指針域。當(dāng)我們做free(p);時(shí)候,其實(shí)是對(duì)它整個(gè)結(jié)點(diǎn)進(jìn)行刪除和內(nèi)存釋放的工作。而我們整表刪除是需要一個(gè)個(gè)結(jié)點(diǎn)刪除的,所以我們就需要q來(lái)記載p的下一個(gè)結(jié)點(diǎn)。這就好比*。單鏈表結(jié)構(gòu)與順序存儲(chǔ)結(jié)構(gòu)優(yōu)缺點(diǎn)我們分別從存儲(chǔ)分配方式、時(shí)間性能、空間性能三方面來(lái)做對(duì)比。存儲(chǔ)分配方式:順序存儲(chǔ)結(jié)構(gòu)用一段連續(xù)的存儲(chǔ)單元依次存儲(chǔ)線性表的數(shù)據(jù)元素。單鏈表采用鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu),用一組任意的存儲(chǔ)單元存放線性表的元素。單鏈表結(jié)構(gòu)與順序存儲(chǔ)結(jié)構(gòu)優(yōu)缺點(diǎn)時(shí)間性能:查找順序存儲(chǔ)結(jié)構(gòu)O(1)單鏈表O(n)插入和刪除順序存儲(chǔ)結(jié)構(gòu)需要平均移動(dòng)表長(zhǎng)一半的元素,時(shí)間
3、為O(n)單鏈表在計(jì)算出某位置的指針后,插入和刪除時(shí)間僅為O(1)單鏈表結(jié)構(gòu)與順序存儲(chǔ)結(jié)構(gòu)優(yōu)缺點(diǎn)空間性能:順序存儲(chǔ)結(jié)構(gòu)需要預(yù)分配存儲(chǔ)空間,分大了,容易造成空間浪費(fèi),分小了,容易發(fā)生溢出。單鏈表不需要分配存儲(chǔ)空間,只要有就可以分配,元素個(gè)數(shù)也不受限制。綜上所述對(duì)比,我們得出一些經(jīng)驗(yàn)性的結(jié)論:若線性表需要頻繁查找,很少進(jìn)行插入和刪除操作時(shí),宜采用順序存儲(chǔ)結(jié)構(gòu)。若需要頻繁插入和刪除時(shí),宜采用單鏈表結(jié)構(gòu)。單鏈表結(jié)構(gòu)與順序存儲(chǔ)結(jié)構(gòu)優(yōu)缺點(diǎn)比如說(shuō)游戲開(kāi)發(fā)中,對(duì)于用戶(hù)注冊(cè)的個(gè)人信息,除了注冊(cè)時(shí)插入數(shù)據(jù)外,絕大多數(shù)情況都是讀取,所以應(yīng)該考慮用順序存儲(chǔ)結(jié)構(gòu)。而游戲中的玩家的武器或者裝備列表,隨著玩家的游戲過(guò)程中,可能會(huì)隨時(shí)增加或刪除,此時(shí)再用順序存儲(chǔ)就不太合適了,單鏈表結(jié)構(gòu)就可以大展拳腳了。當(dāng)線性表中的元素個(gè)數(shù)變化較大或者根本不知道有多大時(shí),最好用單鏈表結(jié)構(gòu),這樣可以不需要考慮存儲(chǔ)空間的大小問(wèn)題。單鏈表結(jié)構(gòu)與順序存儲(chǔ)結(jié)構(gòu)優(yōu)缺點(diǎn)而如果事先知道線性表的大致長(zhǎng)度,比如一年12個(gè)月,一周就是星期一至星期日共七天,這種用順序存儲(chǔ)結(jié)構(gòu)效率會(huì)高很多??傊€性表的順序存儲(chǔ)結(jié)構(gòu)和單鏈表結(jié)構(gòu)各有其優(yōu)缺點(diǎn),不能簡(jiǎn)單的說(shuō)哪個(gè)好,哪個(gè)不好,需要根據(jù)實(shí)
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 鑄造定點(diǎn)澆筑施工方案
- 木質(zhì)坐凳施工方案
- 海淀池子防腐施工方案
- 園林家具施工方案
- 外立面改造施工方案
- 二零二五年度設(shè)施農(nóng)業(yè)土地承包經(jīng)營(yíng)合同
- 2025年度生豬養(yǎng)殖產(chǎn)業(yè)鏈金融服務(wù)合同
- 二零二五年度航空航天市場(chǎng)推廣分紅權(quán)協(xié)議書(shū)
- 2025年度物流運(yùn)輸授權(quán)合作合同
- 2025年度知識(shí)產(chǎn)權(quán)侵權(quán)和解賠款調(diào)解協(xié)議書(shū)
- ?;钒踩芾碇贫确段暮?jiǎn)短危化品安全管理制度和崗位安全操作規(guī)程(3篇)
- 平岡中學(xué)教師任職條件
- 小老鼠找朋友 演示文稿
- GB/T 14163-2009工時(shí)消耗分類(lèi)、代號(hào)和標(biāo)準(zhǔn)工時(shí)構(gòu)成
- 教科版科學(xué)五年級(jí)下冊(cè)《生物與環(huán)境》單元教材解讀及教學(xué)建議
- 英語(yǔ)四六級(jí)翻譯技巧課件
- 讀后續(xù)寫(xiě)(2022新高考I卷)講解課件 高三英語(yǔ)寫(xiě)作專(zhuān)項(xiàng)
- 三角形的內(nèi)角和-課件
- 兒科-補(bǔ)液-液體療法課件
- 口腔健康教育和促進(jìn)
- 廣州市建設(shè)項(xiàng)目代建合同穗政合同示范文本004號(hào)
評(píng)論
0/150
提交評(píng)論