2022年数据结构之双向链表的Java实现 .pdf
《2022年数据结构之双向链表的Java实现 .pdf》由会员分享,可在线阅读,更多相关《2022年数据结构之双向链表的Java实现 .pdf(6页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、数据结构之双向链表的Java 实现单链表只能从前往后遍历, 如果链表的长度较大, 遍历到链表后半部分的时候想要往前查找,就只能回到开头,重新遍历了。双向链表提供了这个能力, 即允许前向遍历, 也允许后向遍历整个链表。 原因是双向链表的每个节点都有两个指向其他节点的引用。但这也是其缺点, 因为在插入、删除的时候需要处理四个链接点的引用,占用的空间也大了一些。如将头节点和尾节点链接起来,即成为双向循环链表。下面是 java 代码:package test; public class DoubleLink public Link first; public Link last; public Dou
2、bleLink() / 构造器,初始化this.first = null; this.last = null; public boolean isEmpty() / 判断是否为空return first = null; public void insertFirst(int idata) / 将元素插入链表开头Link link = new Link(idata );if (isEmpty ()last = link;/ 如果为空, last需要改变else 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - -
3、- - - - - 第 1 页,共 6 页 - - - - - - - - - first.previous = link;/ 非空,则要在 first前插入link.next = first; first = link; public void insertLast(int idata) / 插入链表结尾Link link = new Link(idata );if (isEmpty ()first = link; else last.next = link; link.previous = last; last = link; public boolean insertAfter(int
4、key, int idata) / 在某项元素后插入Link current = first; while (current.idata != key) /从头开始查找current = current.next; if (current = null)/ 到表尾也没有找到return false; Link link = new Link(idata );if (current = last) link.next = null; 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 2
5、页,共 6 页 - - - - - - - - - last = link; else link.next = current.next; current.next.previous = link; link.previous = current; current.next = link; return true; public Link delectKey(int key) / 删除某项元素Link current = first; while (current.idata != key) current = current.next; if (current = null)return n
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2022年数据结构之双向链表的Java实现 2022 数据结构 双向 Java 实现
限制150内