当前位置:首页 > 日记 > 正文

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

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

本文实例讲述了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();//efghijlink.print2();//jihgfeconsole.log(link.getHead());//econsole.log(link.getTail());//jconsole.log(link.indexOf('f'));//1

运行结果:

更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript数据结构与算法技巧总结》、《JavaScript数学运算用法总结》、《JavaScript排序算法总结》、《JavaScript遍历算法与技巧总结》、《JavaScript查找算法技巧总结》及《JavaScript错误与调试技巧总结》

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

相关文章

AI布尔工具绘制一只有趣的大嘴鸟LO

AI布尔工具绘制一只有趣的大嘴鸟LO

工具,布尔,绘制,一只,有趣,这篇文章主要像的朋友们介绍的是使用AI布尔工具绘制大嘴鸟LO,教程其实就是目前比较流行的标准制图绘制思路,个人觉得通幽创意的,推荐过来和的朋友们一起分享、一起学习了,我们先来看看最终的效果图吧:以上就是AI布尔工…

PS2018全景工具之保留细节2.0的使

PS2018全景工具之保留细节2.0的使

工具,全景,使用方法,细节,电脑软件,PS CC 2018新增了很多功能,今天我们就来看看PS2018中全景工具&保留细节2.0工具的使用方法。软件名称:Adobe Photoshop CC 2018 v19.0 简体中文正式版(附注册机+破解教程) 32/64位软件大小:1.53GB更新时间:201…

秒拍视频怎么分享到朋友圈

秒拍视频怎么分享到朋友圈

分享,朋友圈,视频,电脑软件,  秒拍视频怎么分享到QQ空间?秒拍视频怎么分享到微信朋友圈?关于秒拍视频分享问题,小编已在本文公布教程,分别为自己发布的视频分享以及分享别人的视频方法,希望能够帮助到大家。秒拍自己发布的视频怎么分享到微…

Node.js中流 | stream的使用方法示

Node.js中流 | stream的使用方法示

中流,示例,使用方法,电脑软件,Node,前言本文主要给大家介绍了关于Node.js 流(stream)的使用方法,分享出来供大家参考学习,下面话不多说,来一起看看详细的介绍:流是基于事件的API,用于管理和处理数据,而且有不错的效率.借助事件和非阻塞I/O库,流…

Vue-Router进阶之滚动行为详解

Vue-Router进阶之滚动行为详解

进阶,详解,电脑软件,Vue,Router,滚动行为使用前端路由,当切换到新路由时,想要页面滚到顶部,或者是保持原先的滚动位置,就像重新加载页面那样。 vue-router 能做到,而且更好,它让你可以自定义路由切换时页面如何滚动。注意: 这个功能只在 HTML5 hi…

Photoshop设计科技感十足的banner

Photoshop设计科技感十足的banner

教程,电脑软件,Photoshop,感十足,banner,教你使用Photoshop设计科技感十足的banner底图,教程简单粗暴,只要几步即可完成。本次教程内容是来自Seso的作品,充满科技感的效果可以用到科技、家电、电子类产品的Banner的背景中,那么如何设计出这样的…

在bootstrap中实现轮播图实例代码

在bootstrap中实现轮播图实例代码

实例代码,轮播图,电脑软件,bootstrap,Bootstrap中轮播图插件叫作Carousel以下容器就是整个轮播图组件的整体,注意该盒子必须加上 class=”carousel slide” data-ride=”carousel” 表示当 前是一个轮播图bootstrap.js会自动为当前元素添加…

BootStrap中jQuery插件Carousel实

BootStrap中jQuery插件Carousel实

插件,效果,广告,电脑软件,BootStrap,轮播广告在网站中的应用实在是太常见了,下面说一说怎样使用bootstrap中的Carousel插件来实现轮播广告效果,下图为最终效果:具体实现方法请看下面的代码:<div class="carousel slide" data-ride="carousel…

Ps怎么设计出超酷的抽象图案?

Ps怎么设计出超酷的抽象图案?

抽象,超酷,图案,电脑软件,Ps,怎么也想不到,效果图竟是用简单的渐变工具来完成。过程也非常简单:选择黑白渐变后,在属性栏把混合模式改为&ldquo;差值&rdquo;。然后就可以随意拉渐变,即可得到一些抽象图案。后期再通过复制及叠加等做出更为复杂的…

php常用数组函数实例小结

php常用数组函数实例小结

数组函数,实例,常用,电脑软件,php,本文实例总结了php常用数组函数。分享给大家供大家参考,具体如下:1. array array_merge(array $array1 [, array $array2 [, $array]])函数功能:将一个或多个数组的单元合并起来,一个数组中的值附加在前一个…

ps怎么设计一款毛笔字体的水墨字效

ps怎么设计一款毛笔字体的水墨字效

字体,水墨,效果,电脑软件,ps,跟大家分享一下毛笔字怎么做出来的,主要通过字体和素材叠加,十分简单,喜欢的一起练习。做完记得交作业。先看看最终效果:软件名称:Adobe Photoshop 8.0 中文完整绿色破解版软件大小:150.1MB更新时间:2015-11-04软件名…

excel2010密码忘记了的处理方法exc

excel2010密码忘记了的处理方法exc

密码,处理方法,密码保护,忘记了,电脑软件,  在Excel中经常需要用到密码进行对重要数据的保护,但是可能过了段时间过后就已经忘记了密码,这个时候就需要我们用点技巧才可以把文档打开了。今天,小编就教大家Excel2010密码保护忘记的处理方法!Ex…