视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
JavaScript数据结构之双向链表定义与使用方法示例
2020-11-27 22:26:46 责编:小采
文档

本文实例讲述了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<=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<position){
 previous=current;
 current=current.next;
 index++;
 }
 previous.next=node;
 node.previous=previous;
 node.next=current;
 current.previous=node;
 }
 length++;
 return true;
 }else{
 return null;
 }
 }
 this.removeAt=function(position){//删除任意位置的节点
 if(position>-1&&position<length){//边界判断
 var current=head;
 var previous;
 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<position){
 previous=current;
 current=current.next;
 index++;
 }
 previous.next=current.next;
 current.next.previous=previous;
 }
 length--;
 return current.element;
 }else{
 return null;
 }
 }
 this.indexOf=function(e){//获取节点位置,从头开始数
 var current=head;
 var index=0;
 while(current){
 if(current.element==e){
 return index;
 }
 current=current.next;
 index++;
 if(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数算用法总结》、《JavaScript排序算法总结》、《JavaScript遍历算法与技巧总结》、《JavaScript查找算法技巧总结》及《JavaScript错误与调试技巧总结》

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

下载本文
显示全文
专题