欢迎来到天天文库
浏览记录
ID:36502264
大小:1010.00 KB
页数:36页
时间:2019-05-09
《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;headp1
4、p21104189nextn=2p1=newstudentif(p1->num!=0)P2->next=p1;1104390nextp1headp1p21104189next1104390nextp2=p1headp1p21104189next1104390next1104785nextn=3p1=newstudent;headp1p21104189next1104390next1104785nextn=3if(p1->num!=0)p2->next=p1p2=p1headp1p21104189.5next1104390next1104785NULLn=4p1
5、=newstudent;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;els
6、ep2->next=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=he
7、ad;cout<<"Now,Thereare"<num<<'t'<score<<'';p=p->next;}while(p!=NULL);}$7.7.2输出链表从一个链表中删去一个结点,并不一定是真正从内存中把它抹掉,而是把它从链表中分离开来,即改变链接关系。headp11104189next1104390next1104785NULL初始p1=head;$7.7.3对链表的删除操作headp1p21104189next1104390nex
8、t1104785NULL如果不是要删除
此文档下载收益归作者所有