第10章动态数组与链表_第1页
第10章动态数组与链表_第2页
第10章动态数组与链表_第3页
第10章动态数组与链表_第4页
第10章动态数组与链表_第5页
已阅读5页,还剩29页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、第10章动态数组与链表第十章 动态数组与链表第10章动态数组与链表引入问题引入问题1. 求某班级(求某班级(30人)中所有学生的成绩平均分。人)中所有学生的成绩平均分。 float a302. 求任意一个班级(人数不定)中所有学生的成绩求任意一个班级(人数不定)中所有学生的成绩平均分。平均分。方法:求最大班级人数(假设方法:求最大班级人数(假设100),),float a100 解决办法:能不能根据我输入的班级人数,来自动的确解决办法:能不能根据我输入的班级人数,来自动的确定数组长度。定数组长度。 缺点:浪费内存空间缺点:浪费内存空间静态分配静态分配动态分配动态分配第10章动态数组与链表动态存

2、储分配函数动态存储分配函数 malloc函数(memory allocation) void *malloc(int n);calloc函数(count allocation) void *calloc(int count,int n);free函数 void free(void *ptr);realloc函数(reallocation) void *realloc(void *p,int n);使用时包含使用时包含malloc.h或或stdlib.h第10章动态数组与链表int *p,n;Scanf(“%d”,&n);p= malloc(n); (int*)int a10; 40int *p

3、,count,n;Scanf(“%d%d”,&count,&n);p= calloc(count,n);(int*)10 4int *p,n;Scanf(“%d”,&n);p= malloc(n);p= realloc(p,40);(int*)10(int*)free(p)第10章动态数组与链表#include #include void main() float *p,s=0;int num,i; scanf(%d,&num); p=(float*)malloc(num); for (i=0;inum;i+) scanf(%f,p+i); for (i=0;inum;i+) printf(%

4、6.2f,*(p+i); for (i=0;inum;i+) s=s+(*(p+i); printf(n%f,s/num);2. 求任意一个班级(人数不定)求任意一个班级(人数不定)中所有学生的成绩平均分。中所有学生的成绩平均分。第10章动态数组与链表free函数 void free(void *ptr);#include#include#includevoid main() char *str; str=(char *)malloc(10*sizeof(char); strcpy(str,china); printf(String is %sn,str); free(str); printf

5、(String is %sn,str); 第10章动态数组与链表#include#include#includevoid main() char *str; char* m();str=m();printf(String is %sn,str);char* m()char * str;str=(char *)malloc(10*sizeof(char); strcpy(str,china); printf(String is %sn,str); / free(str); /考察考察str所指向的空间什么时候被回收?所指向的空间什么时候被回收? printf(String is %sn,str)

6、;return str 动态内存分配函数是在整个程序运行完毕动态内存分配函数是在整个程序运行完毕时,才回收内存;但是函数的局部变量是时,才回收内存;但是函数的局部变量是在本函数执行完毕时就回收。使用了在本函数执行完毕时就回收。使用了free函数,就可以在执行到该语句时,就能够函数,就可以在执行到该语句时,就能够回收该内存空间。回收该内存空间。第10章动态数组与链表reallocrealloc函数函数void *realloc(void *p,int n); #include #include #include main() char *p; p=(char *)malloc(100); if(

7、p) printf(Memory Allocated at: %x,p); else printf(Not Enough Memory!n); strcpy(p,hello world); p=(char *)realloc(p,600); if(p) printf(Memory Reallocated at: %x,p); else printf(Not Enough Memory!n); free(p);第10章动态数组与链表 #include #include #include main() struct stu int num; char *name; char sex; float

8、score10; struct stu *q; *p; p=(struct stu *)malloc(sizeof(struct stu); scanf(“%s”,p-name);%出现错误!出现错误!Name所指向的存储空间不可用所指向的存储空间不可用 printf(%s,(*p).name); p-name=“zhangsan”;“zhangsan”在常量存储区由编译在常量存储区由编译器自动开辟空间器自动开辟空间第10章动态数组与链表例:跳马。依下图将每一步跳马之后的位置例:跳马。依下图将每一步跳马之后的位置(x,y)(x,y)放放到一个到一个“结点结点”里,再用里,再用“链子穿起来链子穿

9、起来”,形成,形成一条链,相邻两结点间用一个指针将两者连到一一条链,相邻两结点间用一个指针将两者连到一起。起。动态链表动态链表 0 1 2 3 4 5 6 7 8 4 3 2 1 结点结点 1 2 3 4 5 6 7 第10章动态数组与链表依上图有依上图有7个结点个结点x1x1y1y1每个节点既有数据每个节点既有数据(xi(xi和和yi)yi) 又有指针(下个结点的地址),又有指针(下个结点的地址),用什么样的数据类型表示每个节点用什么样的数据类型表示每个节点x2x2y2y2x7x7y7y7x6x6y6y6第10章动态数组与链表 struct nodeint x;int y;构造节点的数据类型

10、构造节点的数据类型struct node *next第10章动态数组与链表链表的几个基本概念链表的几个基本概念x1,y1x1,y11249x2,y2x2,y21356x4,y4x4,y41021x3,y3x3,y314751356147510210NULL12491、链表中的元素称为、链表中的元素称为“结点结点”,每个结点包括数据域和指针域;,每个结点包括数据域和指针域;2、单向链表通常由一个头指针(、单向链表通常由一个头指针(head),用于指向链表第一个结,用于指向链表第一个结点;点;3、单向链表有一个尾结点,该结点的指针部分为、单向链表有一个尾结点,该结点的指针部分为NULL 。尾结点尾

11、结点头指针头指针第一个结点第一个结点第10章动态数组与链表链表的基本操作链表的基本操作(1 1)创建链表创建链表: : 从无到有地建立起一个链表,即往空链表中依次插入若干结点从无到有地建立起一个链表,即往空链表中依次插入若干结点(2 2)检索链表检索链表: : 按给定的检索条件,查找某个结点。按给定的检索条件,查找某个结点。(3 3)插入操作插入操作: : 在结点在结点ki-1ki-1与与kiki之间插入一个新的结点之间插入一个新的结点kk,使链表的节点数增,使链表的节点数增1 1,(4 4)删除操作删除操作: : 删除结点删除结点kiki,使链表的节点数减,使链表的节点数减1 1, (5)(

12、5)打印输出打印输出第10章动态数组与链表1) 1) 创建链表创建链表1)1)定义三个指针变量:头指针(定义三个指针变量:头指针(headhead)、指向尾结)、指向尾结点的指针(点的指针(p2p2)、指向新开辟结点的指针()、指向新开辟结点的指针(p1p1)2)2)结束输入结点的两个方式:结束输入结点的两个方式: 1 1)创建的结点数已知)创建的结点数已知 2 2)创建的节点数事先未知,但通过)创建的节点数事先未知,但通过 输入一个不存在的数作为结束状态。输入一个不存在的数作为结束状态。3)3)模块函数要返回指向结点的指针模块函数要返回指向结点的指针 struct nodestruct no

13、de* * createlist(); createlist();x1,y1x1,y11249x2,y2x2,y21356x4,y4x4,y41021x3,y3x3,y314751356147510210NULL1249第10章动态数组与链表2)2)打印输出链表打印输出链表模块函数中的形参是指向结点的指针,无需返回值模块函数中的形参是指向结点的指针,无需返回值void outputlistvoid outputlist(struct nodestruct node* * ); );void outputlist(struct node *p)while(p!=NULL)printf(%d,%d

14、)n,p-x,p-y);p=p-next;第10章动态数组与链表3)3)检索链表检索链表模块函数中的形参是指向结点的指针。模块函数中的形参是指向结点的指针。void retrievevoid retrieve(struct nodestruct node* *,int x,int y );,int x,int y );void retrieve (struct node *p,int x,int y) while(p) if(p-x=x&p-y=y) printf(FOUND); return; p=p-next; printf(NO FOUND);第10章动态数组与链表4) 4) 对链表的插

15、入操作对链表的插入操作插入结点:通常是在插入一个新的结点后,仍然保持原插入结点:通常是在插入一个新的结点后,仍然保持原有顺序。有顺序。实现关键:实现关键: 寻找插入位置寻找插入位置插入位置共分四种情况(假设原链表从小到大为例):插入位置共分四种情况(假设原链表从小到大为例):1 1、要插入的链表是个空链表、要插入的链表是个空链表2 2、要插入的结点最小、要插入的结点最小3 3、要插入的结点最大、要插入的结点最大4 4、要插入的结在中间、要插入的结在中间第10章动态数组与链表5 5head6 610101515nullnull1212500050008 840004000 如图所示的链表;现在要

16、插入一个结点,该结点中如图所示的链表;现在要插入一个结点,该结点中 的数为的数为1010演示演示5 5200020006 63000300010002000300040005000100080004000第10章动态数组与链表 待插入结点待插入结点p0p0实际上是第一个结点。这时必然有实际上是第一个结点。这时必然有head=nullhead=null。只要让头指针指向。只要让头指针指向 p0 p0 就可以了。就可以了。6nullheadp0实现语句:实现语句:head = p0;p0-next = null;1 1、要插入的链表是个空链表、要插入的链表是个空链表第10章动态数组与链表 链表已建

17、成,待插入结点链表已建成,待插入结点 p0 p0 的数据要比头结的数据要比头结点的数据还要小,点的数据还要小,(p0-num )num)(p0-num )num)2 2、要插入的结点最小、要插入的结点最小6head8512nullheadp0语句为语句为p0-next=head;p0-next=head;head=p0;head=p0;第10章动态数组与链表 链表已建成,待插入结点链表已建成,待插入结点 p0 p0 的数据要比尾结的数据要比尾结点的数据还要大,点的数据还要大,3 3、要插入的结点最大、要插入的结点最大6head81812nullp0p1-next=p0;P0-next=NULL

18、;语句为语句为nullp1第10章动态数组与链表 链表已建成,待插入结点链表已建成,待插入结点 p0 p0 的数据大小位于的数据大小位于已有链表中的中间,已有链表中的中间, 假设假设p0 p0 的数据比的数据比p2p2指向的数据大,比指向的数据大,比p1p1指向的指向的数据小,即数据小,即p0p0插入在插入在p2p2和和p1p1之间。之间。 问题是:如何找到问题是:如何找到p1p1和和p2?p2?4 4、要插入的结在中间、要插入的结在中间第10章动态数组与链表6head81213p015nullp1p2p2-next = p0;p0-next = p1;第10章动态数组与链表 链表已建成,待插

19、入结点链表已建成,待插入结点 p0 p0 的数据大小位于的数据大小位于已有链表中的中间,已有链表中的中间, 假设假设p0 p0 的数据比的数据比p2p2指向的数据大,比指向的数据大,比p1p1指向的指向的数据小,即数据小,即p0p0插入在插入在p2p2和和p1p1之间。之间。 问题是:如何找到问题是:如何找到p1p1和和p2?p2? - -通过循环实现通过循环实现4 4、要插入的结在中间、要插入的结在中间第10章动态数组与链表6head81213nullp015p1p2p1=p1-next ;P2=p2-next;第10章动态数组与链表6head81213nullp015p1p2p1=p1-n

20、ext ;P2=p2-next;第10章动态数组与链表6head81213p015nullp1p2p2-next = p0;p0-next = p1;第10章动态数组与链表 操操 作作 分分 析析需要几个临时指针:需要几个临时指针:P0: P0: 指向待插的结点指向待插的结点; ;初始化:初始化: p0=(struct nodep0=(struct node* * )malloc(sizeof(struct node); )malloc(sizeof(struct node);P1: P1: 在在P1P1指向的结点之前插入新结点;初始化指向的结点之前插入新结点;初始化: : p1=head;p

21、1=head;P2: P2: 在在P2P2指向的结点之后插入新结点;指向的结点之后插入新结点;第10章动态数组与链表在表尾插入在表尾插入在头结点在头结点之前插入之前插入在中间插入在中间插入空表空表p0-numnum第10章动态数组与链表5) 5) 对链表的删除操作对链表的删除操作删除结点原则:删除结点原则: 只是从链表中分离开要删除的结点,撤消原来的链接只是从链表中分离开要删除的结点,撤消原来的链接关系,并释放该结点的空间。关系,并释放该结点的空间。第10章动态数组与链表5) 5) 对链表的删除操作对链表的删除操作 A A1249 B B1356 D D1021 C C14751356147510210 NULL1249p1p2p2-next = p1-next A A1249 B B1356 D D1021 C C14751475147510210 NULL1249p1p2free(p1)第10

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论