JavaScript数据结构之双向链表定义与使用方法示例

前端之家收集整理的这篇文章主要介绍了JavaScript数据结构之双向链表定义与使用方法示例前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

本文实例讲述了JavaScript数据结构之双向链表定义与使用方法分享给大家供大家参考,具体如下:

双向链表和普通链表的区别在于,在链表中,一个节点只有链向下一个节点的链接,而在双向链表中,链接是双向的:一个链向下一个元素,另一个链向前一个元素。

双向链表提供了两种迭代列表的方法:从头到尾,或者反过来。我们也可以访问一个特定节点的下一个或前一个元素。在单向链表中,如果迭代列表时错过了要找的元素,就需要回到列表起点,重新开始迭代。这是双向链表的一个优点。

=0&&position<=length){//判断边界 var node=new Node(e); var current=head; var prevIoUs; var index=0; if(position==0){//在第一个位置添加 if(!head){//链表为空的时候添加第一个节点 head=node; tail=node; }else{ current=head; node.next=current; current.prevIoUs=node; head=node; } }else if(position==length){//在链表末尾添加 current=tail; current.next=node; node.prevIoUs=current; tail=node; }else{ while(index-1&&positionIoUs; var index=0; if(position==0){//删除第一个位置的节点 head=current.next; if(length==1){//如果只有一项 tail=null; }else{ head.prevIoUs=null; } }else if(position==length-1){//删除最后一项 current=tail; tail=current.prevIoUs; tail.next=null; }else{ while(index=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();//efghij link.print2();//jihgfe console.log(link.getHead());//e console.log(link.getTail());//j console.log(link.indexOf('f'));//1

运行结果:

更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》及《

希望本文所述对大家JavaScript程序设计有所帮助。

猜你在找的JavaScript相关文章