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


Posted in Javascript onOctober 27, 2017

本文实例讲述了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 相关文章推荐
一个可绑定数据源的jQuery数据表格插件
Jul 17 Javascript
写出高效jquery代码的19条指南
Mar 19 Javascript
jquery 表格排序、实时搜索表格内容(附图)
May 19 Javascript
Dojo获取下拉框的文本和值实例代码
May 27 Javascript
jQuery多级联动下拉插件chained用法示例
Aug 20 Javascript
微信小程序 基础知识css样式media标签
Feb 15 Javascript
JS异步加载的三种实现方式
Mar 16 Javascript
CodeMirror js代码加亮使用总结
Mar 25 Javascript
vue2项目使用sass的示例代码
Jun 28 Javascript
20170918 前端开发周报之JS前端开发必看
Sep 18 Javascript
vue-cli安装使用流程步骤详解
Nov 08 Javascript
js canvas实现5张图片合成一张图片
Jul 15 Javascript
jQuery判断网页是否已经滚动到浏览器底部的实现方法
Oct 27 #jQuery
动态统计当前输入内容的字节、字符数的实例详解
Oct 27 #Javascript
elemetUi 组件--el-upload实现上传Excel文件的实例
Oct 27 #Javascript
node 利用进程通信实现Cluster共享内存
Oct 27 #Javascript
vue中v-model动态生成的实例详解
Oct 27 #Javascript
微信小程序 input输入及动态设置按钮的实现
Oct 27 #Javascript
js通过Date对象实现倒计时动画效果
Oct 27 #Javascript
You might like
PHP Zip压缩 在线对文件进行压缩的函数
2010/05/26 PHP
PHP设计模式之策略模式原理与用法实例分析
2019/04/04 PHP
jQuery 锚点跳转滚动条平滑滚动一句话代码
2010/04/30 Javascript
JavaScript中各种编码解码函数的区别和注意事项
2010/08/19 Javascript
JavaScript Memoization 让函数也有记忆功能
2011/10/27 Javascript
javascript限制文本框只允许输入数字(曾经与现在的方法对比)
2013/01/18 Javascript
原生js实现半透明遮罩层效果具体代码
2013/06/06 Javascript
JS预览图像将本地图片显示到浏览器上
2013/08/25 Javascript
基于JSON格式数据的简单jQuery幻灯片插件(jquery-slider)
2016/08/10 Javascript
Angular.JS中的this指向详解
2017/05/17 Javascript
手写简单的jQuery雪花飘落效果实例
2018/04/22 jQuery
小程序实现左滑删除功能
2018/10/30 Javascript
JavaScript解析机制与闭包原理实例详解
2019/03/08 Javascript
微信小程序云开发之新手环境配置
2019/05/16 Javascript
[04:22]DSPL第二期精彩集锦:残血反杀!
2014/12/10 DOTA
Python查找相似单词的方法
2015/03/05 Python
python利用urllib实现爬取京东网站商品图片的爬虫实例
2017/08/24 Python
Django读取Mysql数据并显示在前端的实例
2018/05/27 Python
Python用61行代码实现图片像素化的示例代码
2018/12/10 Python
使用Python制作表情包实现换脸功能
2019/07/19 Python
Python中的引用和拷贝实例解析
2019/11/14 Python
python爬取招聘要求等信息实例
2020/11/20 Python
澳大利亚最受欢迎的美发和美容在线商店:Catwalk
2018/12/12 全球购物
ECOSUSI官网:女式皮革背包
2019/09/27 全球购物
"火柴棍式"程序员面试题
2014/03/16 面试题
幼儿园小班家长寄语
2014/04/02 职场文书
三年级评语大全
2014/04/23 职场文书
公关活动策划方案
2014/05/25 职场文书
大学生学雷锋活动总结
2014/06/26 职场文书
应届毕业生求职信范文
2014/07/07 职场文书
化学专业毕业生求职信
2014/07/28 职场文书
2014国庆节幼儿园亲子活动方案
2014/09/16 职场文书
开展党的群众路线教育实践活动工作总结
2014/11/05 职场文书
pytorch 如何把图像数据集进行划分成train,test和val
2021/05/31 Python
GitHub上77.9K的Axios项目有哪些值得借鉴的地方详析
2021/06/15 Javascript
vue动态绑定style样式
2022/04/20 Vue.js