北京 理工大學(xué) C語(yǔ)言 程序設(shè)計(jì) 第十章結(jié)構(gòu)、聯(lián)合與枚舉類型3

上傳人:e****s 文檔編號(hào):241839062 上傳時(shí)間:2024-07-29 格式:PPT 頁(yè)數(shù):11 大?。?5KB
收藏 版權(quán)申訴 舉報(bào) 下載
北京 理工大學(xué) C語(yǔ)言 程序設(shè)計(jì) 第十章結(jié)構(gòu)、聯(lián)合與枚舉類型3_第1頁(yè)
第1頁(yè) / 共11頁(yè)
北京 理工大學(xué) C語(yǔ)言 程序設(shè)計(jì) 第十章結(jié)構(gòu)、聯(lián)合與枚舉類型3_第2頁(yè)
第2頁(yè) / 共11頁(yè)
北京 理工大學(xué) C語(yǔ)言 程序設(shè)計(jì) 第十章結(jié)構(gòu)、聯(lián)合與枚舉類型3_第3頁(yè)
第3頁(yè) / 共11頁(yè)

下載文檔到電腦,查找使用更方便

16 積分

下載資源

還剩頁(yè)未讀,繼續(xù)閱讀

資源描述:

《北京 理工大學(xué) C語(yǔ)言 程序設(shè)計(jì) 第十章結(jié)構(gòu)、聯(lián)合與枚舉類型3》由會(huì)員分享,可在線閱讀,更多相關(guān)《北京 理工大學(xué) C語(yǔ)言 程序設(shè)計(jì) 第十章結(jié)構(gòu)、聯(lián)合與枚舉類型3(11頁(yè)珍藏版)》請(qǐng)?jiān)谘b配圖網(wǎng)上搜索。

1、第十章第十章第十章第十章 結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型用鏈表處理不定長(zhǎng)數(shù)組。用鏈表處理不定長(zhǎng)數(shù)組。用鏈表處理不定長(zhǎng)數(shù)組。用鏈表處理不定長(zhǎng)數(shù)組。什么是鏈表?什么是鏈表?什么是鏈表?什么是鏈表?結(jié)構(gòu)定義:結(jié)構(gòu)定義:結(jié)構(gòu)定義:結(jié)構(gòu)定義:struct struct struct struct studentstudentstudentstudent int int int int num;num;num;num;float score;float score;float score;float score;struct struct struct s

2、truct studentstudentstudentstudent *next;next;next;next;鏈表的分類鏈表的分類鏈表的分類鏈表的分類 單向鏈表、雙向鏈表等。單向鏈表、雙向鏈表等。單向鏈表、雙向鏈表等。單向鏈表、雙向鏈表等。一、鏈表概述一、鏈表概述891018910189.589.5ffcdffcdff02ff0289103891039090fffdfffdffcdffcd89107891078585NULLNULLfffdfffd第八節(jié)第八節(jié)第八節(jié)第八節(jié) 鏈表根底鏈表根底鏈表根底鏈表根底第十章第十章第十章第十章 結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)

3、構(gòu)、聯(lián)合與枚舉類型動(dòng)態(tài)存儲(chǔ)分配函數(shù)動(dòng)態(tài)存儲(chǔ)分配函數(shù)原型:原型:void*void*mallocmalloc(intint size)size)頭文件:頭文件:stdlibstdlib.h.h。功能:功能:分配分配sizesize個(gè)字節(jié)的存儲(chǔ)區(qū)。個(gè)字節(jié)的存儲(chǔ)區(qū)。返回值:返回值:分配成功,所分配區(qū)域的首返回地址。分配成功,所分配區(qū)域的首返回地址。分配失敗,返回分配失敗,返回 0 0。例如:例如:structstruct student student*psps;pspspsps=(=(=(=(structstructstructstruct student student student stud

4、ent*)mallocmallocmallocmalloc(sizeofsizeofsizeofsizeof(structstructstructstruct student student student student););););第十章第十章第十章第十章 結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型釋放內(nèi)存函數(shù)釋放內(nèi)存函數(shù)原型:原型:void free(void*p)void free(void*p)頭文件:頭文件:stdlib.h stdlib.h。功能:釋放功能:釋放p p所指向的內(nèi)存空間。所指向的內(nèi)存空間。返回值:無(wú)返回值:無(wú) 。例如:例如:前

5、面說(shuō)明結(jié)構(gòu)指針前面說(shuō)明結(jié)構(gòu)指針ps,ps,為其分配了內(nèi)存,為其分配了內(nèi)存,釋放內(nèi)存,那么寫:釋放內(nèi)存,那么寫:free(ps);free(ps);第十章第十章第十章第十章 結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型創(chuàng)立鏈表的過(guò)程:創(chuàng)立鏈表的過(guò)程:按照結(jié)構(gòu)的大小分配一塊內(nèi)存區(qū)域。按照結(jié)構(gòu)的大小分配一塊內(nèi)存區(qū)域。將該區(qū)域的首地址賦給一個(gè)頭指針。將該區(qū)域的首地址賦給一個(gè)頭指針。繼續(xù)分配一塊內(nèi)存區(qū)域。繼續(xù)分配一塊內(nèi)存區(qū)域。將該區(qū)域的首地址分配給前一個(gè)結(jié)點(diǎn)的結(jié)點(diǎn)指針將該區(qū)域的首地址分配給前一個(gè)結(jié)點(diǎn)的結(jié)點(diǎn)指針變量。變量。繼續(xù)上述過(guò)程,直到鏈表的尾。繼續(xù)上述過(guò)程,直到鏈

6、表的尾。二、創(chuàng)立鏈表二、創(chuàng)立鏈表第十章第十章第十章第十章 結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型 ps f1aa 8019189.5NULL89107 85 NULL 89103 80 NULLps=(ps=(struct studentstruct student *)mallocmalloc(sizeof(sizeof(struct studentstruct student)scanf(“%ld,%fscanf(“%ld,%f,&ps-num,&ps-score);,&ps-num,&ps-score);ps-next=NULL;ps-next=

7、NULL;p1p1=(struct student=(struct student*)mallocmalloc(sizeof(sizeof(struct studentstruct student)p1 ffe4 ps-next=p1ps-next=p1ffe4 ff4d 例例例例C11_701C11_701C11_701C11_701第十章第十章第十章第十章 結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型headheadp1p1p2p2n=0headheadp1p1p2p2n=1p1p1n=2p2p2p1p1n=3p2p2NULLNULL例例例例C11_70

8、1aC11_701aC11_701aC11_701ap1=p2p1=p2=(struct student=(struct student*)mallocmalloc(sizeof(sizeof(struct studentstruct student)head=NULLhead=NULLp2-next=p1p2-next=p1p2-next=p1p2-next=p1第十章第十章第十章第十章 結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型struct student*creat()struct student*creat()struct student*crea

9、t()struct student*creat()do do do do scanf(%ld,%d,&num,&a);scanf(%ld,%d,&num,&a);scanf(%ld,%d,&num,&a);scanf(%ld,%d,&num,&a);if(num!=0)if(num!=0)if(num!=0)if(num!=0)if(if(if(if(headheadheadhead=NULL)=NULL)=NULL)=NULL)headheadheadhead=tailtailtailtail;else else else else tailtailtailtail=tailtailtail

10、tail-next;-next;-next;-next;tail-num=num;tail-num=num;tail-num=num;tail-num=num;tail-score=a;tail-score=a;tail-score=a;tail-score=a;tail-next=(struct student*)malloc(LEN);tail-next=(struct student*)malloc(LEN);tail-next=(struct student*)malloc(LEN);tail-next=(struct student*)malloc(LEN);else tail-ne

11、xt=NULL;else tail-next=NULL;else tail-next=NULL;else tail-next=NULL;while(num!=0);while(num!=0);while(num!=0);while(num!=0);return(head);return(head);return(head);return(head);第十章第十章第十章第十章 結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型 if(head=NULL)head=tail;if(head=NULL)head=tail;if(head=NULL)head=tail;i

12、f(head=NULL)head=tail;else else else else tail=tail-next;tail=tail-next;tail=tail-next;tail=tail-next;tail-num=num;tail-score=a;tail-num=num;tail-score=a;tail-num=num;tail-score=a;tail-num=num;tail-score=a;tail-next=(struct student*)malloc(LEN);tail-next=(struct student*)malloc(LEN);tail-next=(struc

13、t student*)malloc(LEN);tail-next=(struct student*)malloc(LEN);headheadtailtailtailtail第十章第十章第十章第十章 結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型 從頭結(jié)點(diǎn)開始,到尾結(jié)點(diǎn)結(jié)束。從頭結(jié)點(diǎn)開始,到尾結(jié)點(diǎn)結(jié)束。尾結(jié)點(diǎn)的特征:其指向?yàn)榭?。尾結(jié)點(diǎn)的特征:其指向?yàn)榭铡H?、輸出一個(gè)鏈表三、輸出一個(gè)鏈表第十章第十章第十章第十章 結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型l刪除一個(gè)結(jié)點(diǎn),刪除一個(gè)結(jié)點(diǎn),既讓上一個(gè)結(jié)點(diǎn)既讓上一個(gè)結(jié)點(diǎn)指向下一個(gè)結(jié)點(diǎn)。

14、指向下一個(gè)結(jié)點(diǎn)。三、在鏈表中刪除一個(gè)節(jié)點(diǎn)三、在鏈表中刪除一個(gè)節(jié)點(diǎn)f1aa f1aa 801918019189.589.5ffe4ffe489107 89107 85 85 NULL NULL 89103 89103 80 80 ff4d ff4d頭指針頭指針 psps(ps-1)-next=ps-next(ps-1)-next=ps-next801918019189.589.5ffe4ffe4ff4d ff4d 第十章第十章第十章第十章 結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型結(jié)構(gòu)、聯(lián)合與枚舉類型l插入一個(gè)結(jié)點(diǎn),插入一個(gè)結(jié)點(diǎn),既插入處前一個(gè)既插入處前一個(gè)結(jié)點(diǎn),指向結(jié)點(diǎn),指向

15、新結(jié)新結(jié)點(diǎn)點(diǎn),新結(jié)點(diǎn)新結(jié)點(diǎn)指向指向一個(gè)結(jié)點(diǎn)。一個(gè)結(jié)點(diǎn)。四、在鏈表中插入一個(gè)節(jié)點(diǎn)四、在鏈表中插入一個(gè)節(jié)點(diǎn)f1aa f1aa 801918019189.589.5ffe4ffe489107 89107 85 85 NULL NULL 頭指針頭指針ff4d ff4d 89103 89103 80 80 ff4d ff4d pspsffdd ffdd ffdd ffdd ps-next=head-next;ps-next=head-next;ps=(struct student*)malloc(sizeof(struct studet);ps=(struct student*)malloc(sizeof(struct studet);head-next=ps-next;head-next=ps-next;

展開閱讀全文
溫馨提示:
1: 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
5. 裝配圖網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

相關(guān)資源

更多
正為您匹配相似的精品文檔
關(guān)于我們 - 網(wǎng)站聲明 - 網(wǎng)站地圖 - 資源地圖 - 友情鏈接 - 網(wǎng)站客服 - 聯(lián)系我們

copyright@ 2023-2025  zhuangpeitu.com 裝配圖網(wǎng)版權(quán)所有   聯(lián)系電話:18123376007

備案號(hào):ICP2024067431號(hào)-1 川公網(wǎng)安備51140202000466號(hào)


本站為文檔C2C交易模式,即用戶上傳的文檔直接被用戶下載,本站只是中間服務(wù)平臺(tái),本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)上載內(nèi)容本身不做任何修改或編輯。若文檔所含內(nèi)容侵犯了您的版權(quán)或隱私,請(qǐng)立即通知裝配圖網(wǎng),我們立即給予刪除!