循环链表与双向链表_第1页
循环链表与双向链表_第2页
循环链表与双向链表_第3页
循环链表与双向链表_第4页
循环链表与双向链表_第5页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

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

文档简介

1、循环链表与双向链表数 据 结 构链表1.1 循环链表循环链表(circular linked list)是一种首尾相接的链表,将单链表表尾结点原来的空指针改为指向表头结点,就成为循环链表。循环链表并不多占存储单元,但从循环链表的任一个结点出发都可以访问到此链表的每一个结点,因为当访问到表尾结点后又能返回到头结点。 链表1. 带头指针的循环链表通常在循环链表的表头结点前面再加一个空结点,也叫空表头结点。表空时空表头结点的指针指向其本身,如下面的图所示为空循环链表。 空表头结点除指针以外的数据域是没有用的,但为了将此结点与一般结点相区别,常常是将其赋以一个特别的数据,以与一般结点相区别。 链表2.

2、 带尾指针的循环链表另一种方法是不设头指针而改设尾指针,这样无论是找头结点还是尾结点都很方便。因为尾结点由尾指针rear来指示,则头结点的位置是rear-next-next。 链表1.2 双链表 双向链表中每个结点除了有向后指针外,还有指向其前一个结点的指针,这样形成的链表中有两条不同方向的链,因此从某一结点均可向两个方向访问。 双链表的结点形式为: 其中链域prior和next分别指向本结点的直接前趋和直接后继结点。 链表如果循环链表的结点再采用双向指针,就成为双向循环链表。链表双链表较单链表虽然要多占用一些存储单元,但对其插入和删除操作以及查找结点的前趋和后继都非常方便。 双链表结构是一种

3、对称结构,设指针p指向双链表的某一结点,则双链表的对称性可用下式来表示: p=(p-prior)-next=(p-next)-prior 即结点*p的地址既存放在其前趋结点 *(p-prior)的后继指针域中,又存放在它的后继结点*(p-next)的前趋指针域中。 链表1. 双链表的插入设要在p所指结点的前面插入一个新结点*q,则需要修改4个指针 :q-prior=p-prior; q-next=p; (p-prior)-next=q; p-prior=q; 链表2. 双链表的删除设p指向待删除的结点,则删除该结点步骤为:(p-prior) -next=p-next; (p-next) -prior=p-prior; 这两个语句的执行顺序可

温馨提示

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

评论

0/150

提交评论