javascript实现链表

一:线性表的定义

线性表是一种数结构;线性表有两种存储方式连续存储以及链表存储;其基本组成称为数据节点;

1:连续存储

    当使用连续存储的时候系统会为线性表分配一个连续的存储空间;假设每一个节点平均长度为L;每个节点的首存储位置定义为每个节点的存储位置的时候,则 每个节点之间存在下列关系LOC(ai+1)=LOC(ai)+L;LOC(ai)=LOC(a1)+(L-1)*l.

    ai称为a(i+1)的后继,a(i-1)称为ai的前驱。

2:链表实现

使用链表结构实现线性表。即每个节点包括数据部分以及指针部分。即每个数据节点的位置不一定是物理上的相连只需要逻辑上的相连即可即通过指针实现链表的串联

    2-1:链表的分类

    单向链表/循环链表/双向链表/静态链表

    静态链表:就是用数组描述的链表。也就是数组中每一个下表都是一个“节”包含了数据与指向

    循环链表:由于单链表的只会往后方传递,所以到达尾部的时候,要回溯到首部会非常麻烦,所以把尾部节的链与头连接起来形成循环

    双向链表:针对单链表的优化,让每一个节都能知道前后是谁,所以除了后指针域还会存在一个前指针域,这样提高了查找的效率,不过带来了一些在设计上的复杂度,总体来说就是空间换时间了

二:具体单链表实现

    1:最基本的单项链表实现

function list(){

    var _this,prev=null;

return {

    add:function(val){

    prev={

        data:val,

        next:prev||null

    }

}

var li=list();

list.add("mike");

list.add("alice");

list.add("jim");

通过node对象的next去直引用下一个node对象,初步是实现了通过链表的引用,这种链式思路jQuery的异步deferred中的then方法,还有日本的cho45的jsderferre中都有用到。这个实现上还有一个最关键的问题,我们怎么动态插入数据到执行的节之后?

2:查找当前节点

所以我们必须 要设计一个遍历的方法,用来搜索这个node链上的数据,然后找出这个对应的数据把新的节插入到当前的链中,并改写位置记录

var find=function findNode(cur){

    return function(key){

        while(cur.data!=key)

        {

            cur=cur.next;

        }

        return cur;

    }

} (headNode);

3:将指定节点插入到指定节点之后

function node(data)

{

    this.data=data;

    this.next=null

}

var headNode=new node(data);

var findnode=function findnodecreate(cur){

    return function(key){

        while(cur.data!=key)

        {

            cur=cur.next;

        }

        return cur;

    }

}

this.insert=function(data,key){

    var node=new node(data);

    var cur=findNode(key);

    node.next=cur.next;

    cur.next=node;

}

4:删除节点

    由于链表的特殊性,我们a->b->c->d  ,如果要删除c那么就必须修改b.next->c为 b.next->d,所以找到前一个节修改其链表next地址,这个有点像dom操作中removeChild找到其父节点调用移除子节点

同样的我们也在remove方法的设计中,需要设计一个遍历往上回溯一个父节点即可

var findPrevious=function(cur){

    return function(key)

    {

        while(!(cur.next==null)&&cur.next.data!=key)

        {

            cur=cur.next;

        }

    }

}(headnode);

this.remove=function(key){

    var pre=findPrevious(key)

    if(pre.next!=null)

    {

        pre.next=pre.next.next;

    }

}

三:双链表实现


insert的改变

this.insert=function(data,key)

{

     var newNode = new createNode(data);

    //在链条中找到对应的数据节

    //然后把新加入的挂进去

     var current = findNode(headNode,key);

    //插入新的接,更改引用关系

    newNode.next = current.next;

    newNode.previous = current

    current.next = newNode;

};

delete 的改变

this.remove = function(key) {

var currNode = findNode(headNode,key);

if (!(currNode.next == null)) {

    currNode.previous.next = currNode.next;

    currNode.next.previous = currNode.previous;

    currNode.next = null;

    currNode.previous = null;

}

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352

推荐阅读更多精彩内容

  • //leetcode中还有花样链表题,这里几个例子,冰山一角 求单链表中结点的个数----时间复杂度O(n)这是最...
    暗黑破坏球嘿哈阅读 1,515评论 0 6
  • 一、基本数据类型 注释 单行注释:// 区域注释:/* */ 文档注释:/** */ 数值 对于byte类型而言...
    龙猫小爷阅读 4,258评论 0 16
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,621评论 18 399
  • 马太效应指的是强者愈强、弱者愈弱、胜者通吃的现象。经常被社会学家和经济学家们引用的术语,反映的社会现象是两极分化,...
    臧叔阅读 1,644评论 0 3
  • 每一位期待怀孕的妈妈都希望健康怀孕并能生育一个健康宝宝来。但随着环境的改变,饮食结构的变化,妇科炎症及反复人流对生...
    54d9dc8cb47e阅读 647评论 1 4