![指针与链表课件_第1页](http://file4.renrendoc.com/view/3261b267c08a470f390b3051c5ebd194/3261b267c08a470f390b3051c5ebd1941.gif)
![指针与链表课件_第2页](http://file4.renrendoc.com/view/3261b267c08a470f390b3051c5ebd194/3261b267c08a470f390b3051c5ebd1942.gif)
![指针与链表课件_第3页](http://file4.renrendoc.com/view/3261b267c08a470f390b3051c5ebd194/3261b267c08a470f390b3051c5ebd1943.gif)
![指针与链表课件_第4页](http://file4.renrendoc.com/view/3261b267c08a470f390b3051c5ebd194/3261b267c08a470f390b3051c5ebd1944.gif)
![指针与链表课件_第5页](http://file4.renrendoc.com/view/3261b267c08a470f390b3051c5ebd194/3261b267c08a470f390b3051c5ebd1945.gif)
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第10章指针与链表1第10章指针与链表1分析在各种信息管理系统的程序设计中,常常需要存储大量的数据记录。
如果使用结构体数组会带来哪些问题?2解决办法:
采用动态存储分配的数据结构——链表分析在各种信息管理系统的程序设计中,常常需要存储大10.1存储空间的分配与释放
C语言标准函数库stdlib.h中提供了四个函数,用于实现内存的动态分配和释放。分别为:malloc(),calloc(),realloc()和free().1.malloc函数void*malloc(unsignedintsize);作用是:在内存的动态存储区申请一个长度为size的连续空间,并返回存储空间的起始地址;如果没有足够的内存空间可分配,则返回空指针NULL.310.1存储空间的分配与释放C语言标准函数库s用法:由于函数返回类型为void,因此如果要将函数返回的指针赋给其它类型的指针变量,应当进行强制类型转换。
例如:int*p=(int*)malloc(sizeof(int));structstud*p=(structstud*)malloc(sizeof(structstud));4用法:由于函数返回类型为void,因此如果要将函数返回的指针2.calloc函数
void*calloc(unsignedn,unsignedsize);作用是:在内存的动态区分配n个长度为size的连续空间,并返回该存储空间的起始地址。主要用于为动态数组申请存储空间。例如:Int*p=(int*)calloc(10,sizeof(int));52.calloc函数void*calloc(unsign3.free函数voidfree(void*p);作用是:释放指针变量p指向的存储空间.注意:p只能是程序中此前最后一次调用malloc或calloc函数所返回的地址。例如:int*p,*q=(int*)calloc(10,sizeof(int));p=q;q++;free(p);63.free函数voidfree(void*p);作10.2链式存储结构——链表链表可以动态的进行存储分配,每一个元素称为一个“结点”,每个结点都包括两部分:1249head1249A13561356B14751475C10211021DNULLhead:
头指针,存放一个地址,指向链表中的第一个结点.1.数据域:存储用户需要的实际数据;2.指针域:指向下一个结点的地址.表尾:它的地址部分放一个“NULL”,链表到此结束.710.2链式存储结构——链表链表可以动态的进行存储10.3单链表每个结点只含有一个指针,所有结点单向联系,每个结点的指针都指向下一个结点,形成一条线性链。带头结点的单向链表:在单向链表的第一个结点前虚加一个“头结点”,头指针head指向头结点,头结点的指针域指向第一个结点,头结点的数据域不使用。810.3单链表每个结点只含有一个指针,所有可用结构体类型的变量来存储链表中的结点元素.1249head1249A13561356B14751475C10211021DNULL每一个结点中存放地址的部分可用指针来实现.例:structstudent{intnum;floatscore;
structstudent*next;}1、建立和输出链表9可用结构体类型的变量来存储链表中的结点元素.1249h简单静态链表#defineNULL0structstudent{longnum;floatscore;structstudent*next;};main(){structstudenta,b,c,*head,*p;a.num=9901;a.score=89.5;b.num=9903;b.score=90;c.num=9905;c.score=85;
head=&a;a.next=&b;b.next=&c;c.next=NULL;p=head;do{printf(“%ld%5.2f\n”,p->num,p->score);
p=p->next;}while(p!=NULL);}anumscorenextbcheadp990189.5990390990585&a&b&cNULL&a&b&cNULL10简单静态链表#defineNULL0anumscore建立动态链表#defineNULL0#defineLENsizeof(structstudent)structstudent{longnum;floatscore;structstudent*next;};intn;动态建立链表structstudent*creat(void){structstudent*head,*pEnd,*pNew;n=0;pEnd=pNew=(structstudent*)malloc(LEN);scanf(“%ld,%f”,&pNew->num,&pNew->score);head=NULL;while(pNew->num!=0){n=n+1;if(n==1)head=pNew;elsepEnd->next=pNew;pEnd=pNew;pNew=(structstudent*)malloc(LEN);scanf(“%ld,%f”,&pNew->num,&pNew->score);}pEnd->next=NULL;return(head);}11建立动态链表#defineNULL0动态建立链表11链表的插入操作3、单链表的插入structstudent*insert(structstudent*head,structstudent*stud){structstudent*p1,*p2;p1=head;if(head==NULL){head=stud;stud->next=NULL;}else{while(p1->num>stud->num&&p1->next!=NULL)){p2=p1;p1=p1->next;}if(p1->next!=NULL){if(head==p1)head=stud;elsep2->next=stud;stud->next=p1;}else{p1->next=stud;stud->next=NULL;}}n=n+1;return(head);}12链表的插入操作3、单链表的插入12链表的删除操作4、单链表的删除structstudent*del(structstudent*head,longnum){structstudent*p1,*p2;
if(head==NULL)
{printf(“\nlistnull!\n”);exit(0);}p1=head;while(num!=p1->num&&p1->next!=NULL){p2=p1;p1=p1->next;}
if(num==p1->num){if(p1==head)head=p1->next;elsep2->
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025至2030年长柄打气嘴项目投资价值分析报告
- 2025年压敏热熔胶项目项目风险识别与评估综合报告
- 基于机器视觉的烟叶含梗检测及尺寸结构分析算法研究
- 卟啉基超支化聚酰亚胺电存储材料的制备及性能研究
- 装配式混凝土隔震结构临时支撑设计及施工阶段力学性能研究
- 2025年新型功能材料项目发展计划
- 基于软件预取的程序访存性能优化研究
- 2025年01月河南中原细胞和免疫治疗实验室(郑州)公开招聘工作人员笔试历年典型考题(历年真题考点)解题思路附带答案详解
- 基于生态流量保障的东方红水库优化调度研究
- 基于深度学习的道路病害检测方法研究
- 电动汽车用驱动电机系统-编制说明
- 江苏卷2024年高三3月份模拟考试化学试题含解析
- 门诊导诊课件
- 2024年四川省成都市新都区中考英语一诊试卷(含解析)
- 《树立正确的“三观”》班会课件
- ISO15614-1 2017 金属材料焊接工艺规程及评定(中文版)
- 医疗器械物价收费申请流程
- “一带一路”背景下的西安市文化旅游外宣翻译研究-基于生态翻译学理论
- 2024年江苏省昆山市六校中考联考(一模)化学试题
- 国家电网智能化规划总报告
- 妊娠纹培训课件
评论
0/150
提交评论