本文主要介绍了javascript数据结构之双向链表定义与使用方法,简单介绍了双向链表的原理,并结合实例形式分析了双向链表的定义与使用方法,需要的朋友可以参考下,希望能帮助到大家。
双向链表和普通链表的区别在于,在链表中,一个节点只有链向下一个节点的链接,而在双向链表中,链接是双向的:一个链向下一个元素,另一个链向前一个元素。
双向链表提供了两种迭代列表的方法:从头到尾,或者反过来。我们也可以访问一个特定节点的下一个或前一个元素。在单向链表中,如果迭代列表时错过了要找的元素,就需要回到列表起点,重新开始迭代。这是双向链表的一个优点。
function DoubleLink(){ var length=0;//链表长度 var head=null;//头结点的引用 var tail=null;//尾节点的引用 function Node(e){ this.element=e; this.next=null; this.previous=null; } this.insertAt=function(position,e){//在任意位置添加节点 if(position>=0&&position-1&&position=length)return null; } } this.isEmpty=function(){//判断链表是否为空 return length==0; } this.mylength=function(){//链表长度 return length; } this.print1=function(){//从头到尾打印链表 var current=head; while(current){ console.log(current.element); current=current.next; } } this.print2=function(){//从尾到头打印链表 var current=tail; while(current){ console.log(current.element); current=current.previous; } } this.getHead=function(){//获取头节点 return head; } this.getTail=function(){//获取尾节点 return tail; }}var link=new DoubleLink();//实例化一个对象link.insertAt(0,'d');link.insertAt(1,'e');link.insertAt(2,'f');link.insertAt(3,'g');link.insertAt(4,'h');link.insertAt(5,'i');link.insertAt(6,'j');link.insertAt(7,'k');link.removeAt(7);link.removeAt(0);link.print1();//efghijlink.print2();//jihgfeconsole.log(link.getHead());//econsole.log(link.getTail());//jconsole.log(link.indexOf('f'));//1
登录后复制
运行结果:
立即学习“Java免费学习笔记(深入)”;
相关推荐:
实例详解PHP基于双向链表与排序操作实现的会员排名功能
JavaScript双向链表和双向循环链表的实现
PHP小教程之实现双向链表_PHP教程
以上就是JavaScript双向链表定义与使用方法的详细内容,更多请关注【创想鸟】其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2790293.html