vc程序设计链表与链表的基本操作

vc程序设计链表与链表的基本操作

ID:39991495

大小:1.18 MB

页数:36页

时间:2019-07-16

vc程序设计链表与链表的基本操作_第1页
vc程序设计链表与链表的基本操作_第2页
vc程序设计链表与链表的基本操作_第3页
vc程序设计链表与链表的基本操作_第4页
vc程序设计链表与链表的基本操作_第5页
资源描述:

《vc程序设计链表与链表的基本操作》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、VC++程序设计链表与链表的基本操作链表是一种动态地进行存储分配的结构。最简单的链表称为单向链表,如图所示:1249A1356B1475C1021DNULLHead1249135614751021特点:1。头指针变量head,它存放一个地址,用于指向一个元素。链表中的一个元素称为结点。2。每个结点至少应包含两个部分:一为用户需要的实际数据,二为下一个结点的地址。3。“表尾”的地址部分放一个“Null”(表示“空地址”)。表示链表的最后一个元素,该元素不再指向其它元素。简单链表链表中各元素在内存中一般是不连续的。要找某一元素,必须先找到上一个元素,根据它提供的下一个

2、元素的地址才能找到下一个元素。可见,如果不提供头指针,则整个链表都无法访问。由于链表的每个结点中都必须包含一个指向下一结点的指针变量和一个结点数据,因此可以用前面介绍的结构体类型的变量实现。在定义一个结构体类型时,包含若干成员,而其中成员之一必须是一个指针变量,该指针变量用于指向下一个具有相同结构体类型的变量---“结点”。structstudent{intnum;intscore;student*next;};建立链表一般包括以下几个步骤:1、建立链表头head2、使用动态内存分配技术,在内存中动态建立链表中的各个结点,并使链表头head指针next指向第一结点

3、,同时,每个结点的next指针逐一指向下一结点。3、使链尾结点的指针next指向空结点NULL。例:写一函数建立一个有3名学生数据(学号、成绩)的单向链表(以输入num为0表示结束输入)。structstudent{intnum;intscore;student*next;};student*head,*p1,*p2;1104189.5next1104390next1104785NULLnumscorenext$7.1建立链表headp1p21104189nextn=1if(p1->num!=0)head=p1=p2=newstudent;headp1p21104

4、189nextn=2p1=newstudentif(p1->num!=0)P2->next=p1;1104390nextp1headp1p21104189next1104390nextp2=p1headp1p21104189next1104390next1104785nextn=3p1=newstudent;headp1p21104189next1104390next1104785nextn=3if(p1->num!=0)p2->next=p1p2=p1headp1p21104189.5next1104390next1104785NULLn=4p1=newstud

5、ent;if(p1->num==0)p2->next=NULL;return(head);00//建立链表的C++语言函数如下:student*creat(void){student*head,*p1,*p2;number=0;//结点记数器,全局变量head=NULLp1=p2=newstudent;//产生第一个结点cout<<"num:";cin>>p1->num;cout<<"score:";cin>>p1->score;while(p1->num!=0){number++;//结点记数器if(number==1)head=p1;elsep2->next=

6、p1;p2=p1;p1=newstudent;//产生下一个结点cout<<"num:";cin>>p1->num;cout<<"score:";cin>>p1->score;}p2->next=NULL;//链表尾deletep1;return(head);}要输出链表,首先要知道链表头的地址,然后用一个指针指向第一个结点,输出该结点的数据成员p->num和p->score,再使p指向下一结点,再输出,直到链表的尾结点p->next==NULL。程序如下:voidprint(student*head){structstudent*p=head;cout<<"

7、Now,Thereare"<num<<'t'<score<<'';p=p->next;}while(p!=NULL);}$7.7.2输出链表从一个链表中删去一个结点,并不一定是真正从内存中把它抹掉,而是把它从链表中分离开来,即改变链接关系。headp11104189next1104390next1104785NULL初始p1=head;$7.7.3对链表的删除操作headp1p21104189next1104390next1104785NULL如果

8、不是要删除

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。