链表相比数组更具灵活性和扩展性。主要有节点数据以及指向节点的指针所构成。

链表中节点的实现【元素和指针】:

        let Node = function( element ){
this.element = element;
this.next = null;
};

单链表的实现:

function LinkedList(){
let Node = function( element ){
this.element = element;
this.next = null;
}; let head = null;
let length = 0; this.append = function( element ){
let newNode = new Node( element );
let current = null;
if( head == null ){
head = newNode;
}else{
current = head;
while( current.next ) {
current = current.next;
}
current.next = newNode;
}
length++;
}; this.size = function(){
return length;
}; this.removeAt = function( pos ){
if( pos > -1 && pos < length ){
var current = head,
index = 0,
prev = null; if( pos == 0 ){
head = current.next;
}else{
while( index++ < pos ){
prev = current;
current = current.next;
}
prev.next = current.next;
length--;
return current.element;
}
}else{
return null;
}
}; this.print = function(){
let current = head;
while( current ){
console.log( current.element );
current = current.next;
}
}; this.insert = function( pos, element ){
let newNode = new Node( element );
let current, prev, index = 0;
current = head;
if( pos >= 0 && pos <= length ){
if( pos == 0 ){
newNode.next = head;
head = newNode;
}else{
while( index++ < pos ){
prev = current;
current = current.next;
}
newNode.next = current;
prev.next = newNode;
}
length++;
return true;
}else {
return false;
}
};
this.toString = function(){
let current = head, string = '';
while( current ){
string += current.element + ',';
current = current.next;
}
return string.substring( 0, string.length - 1 );
};
this.indexOf = function( element ){
let current = head, index = -1;
while( current ){
index++;
if( current.element == element ){
return index;
}
current = current.next;
}
return -1;
};
this.remove = function( element ){
let pos = this.indexOf( element );
return this.removeAt( pos );
};
this.isEmpty = function(){
return length == 0;
};
this.getHead = function(){
return head;
}
} var oLink = new LinkedList();
oLink.append( "java" );
oLink.append( "php" );
oLink.append( "javascript" );
oLink.append( "python" ); oLink.print();
console.log( "-----------------------节点个数------------------------")
console.log( oLink.size() ); console.log( "-----------------------删除第2个元素之前------------------------")
console.log( oLink.removeAt( 2 ) );
console.log( "-----------------------删除第2个元素之后------------------------")
oLink.print();
console.log( "节点个数");
console.log( oLink.size() );
console.log( "-----------------------插入节点前------------------------")
oLink.insert( 0, "c语言" );
oLink.insert( 3, "c++语言" );
console.log( "-----------------------插入节点后------------------------")
oLink.print();
oLink.insert( 4, "erlang语言" );
console.log( "-----------------------插入节点后------------------------")
oLink.print();
console.log( "-----------------------节点个数------------------------")
console.log( oLink.size() ); console.log( "-----------------------toString------------------------")
console.log( oLink.toString() );
console.log( "------------------------indexOf-----------------------" );
console.log( oLink.indexOf( "c语言2" ) );
console.log( "------------------------clear-----------------------" );
oLink.print();

javascript算法-单链表的更多相关文章

  1. js数据结构与算法--单链表的实现与应用思考

    链表是动态的数据结构,它的每个元素由一个存储元素本身的节点和一个指向下一个元素的引用(也称指针或链接)组成. 现实中,有一些链表的例子. 第一个就是寻宝的游戏.你有一条线索,这条线索是指向寻找下一条线 ...

  2. 数据结构&算法-单链表

    1.引言 工作一年了,感觉越来越懒散,把很多基础性的东西都慢慢遗忘了,最近想趁着还没忘完,回顾一下,整理了点笔记,分享一下. 如有错的地方,欢迎大家怒喷. 2.学习 我们就从最简单的链表开始吧. 链表 ...

  3. [算法] 单链表插入排序(java)

    实现 首先保证插入前的链表是个完整的,最后一个节点要断开 然后在插入前链表中找到比待插入节点大的最小元素,插到前面即可 Link.java class Link { private class Nod ...

  4. javascript实现数据结构与算法系列:线性表的静态单链表存储结构

    有时可借用一维数组来描述线性链表,这就是线性表的静态单链表存储结构. 在静态链表中,数组的一个分量表示一个结点,同时用游标(cur)代替指针指示结点在数组中的相对位置.数组的第0分量可看成头结点,其指 ...

  5. 数据结构算法C语言实现(二)---2.3线性表的链式表示和实现之单链表

    一.简述 [暂无] 二.头文件 #ifndef _2_3_part1_H_ #define _2_3_part1_H_ //2_3_part1.h /** author:zhaoyu email:zh ...

  6. Reverse反转算法+斐波那契数列递归+Reverse反转单链表算法--C++实现

    Reverse反转算法 #include <iostream> using namespace std; //交换的函数 void replaced(int &a,int & ...

  7. C++ 单链表的基本算法

    线性表是最简单,最常用的一种数据结构.线性表的逻辑结构是n个数据元素的有限序列(a1,a2,…,an).而线性表的物理结构,我们已经学习过顺序表,也就是数组 :另一种线性表的物理结构——链表 . 什么 ...

  8. 特殊的反转单链表算法(C++)

    普通的单链表反转算法 大学的时候也做过好几次单链表的反转,记得当时都是用三个变量不断修改next的值然后实现反转. ListNode* reverseList(ListNode* head) { Li ...

  9. cc150:实现一个算法来删除单链表中间的一个结点,仅仅给出指向那个结点的指针

    实现一个算法来删除单链表中间的一个结点,仅仅给出指向那个结点的指针. 样例: 输入:指向链表a->b->c->d->e中结点c的指针 结果:不须要返回什么,得到一个新链表:a- ...

随机推荐

  1. 2019-4-29 js学习笔记

    js学习笔记一:js数据类型   1:基本数据类型       number类型(整数,小数)      String类型          boolean类型        NaN类型其实是一个nu ...

  2. 吴恩达机器学习笔记45-使用支持向量机(Using A SVM)

    本篇我们讨论如何运行或者运用SVM. 在高斯核函数之外我们还有其他一些选择,如:多项式核函数(Polynomial Kernel)字符串核函数(String kernel)卡方核函数( chi-squ ...

  3. java核心技术-(总结自杨晓峰-java核心技术36讲)

    1. 谈谈你对java平台的理解 首先是java最显著的两个特性,一次写入处处运行:还有垃圾收集器gc,gc能够对java内存进行管理回收,程序员不需要关心内存的分配和回收问题 然后谈谈jre和jdk ...

  4. 解决Python中PyCharm导入模块时,模块名下出现红色波浪线的问题

    在博主第一次在PyCharm中导入模块时,模块名下出现红色波浪线,不影响程序执行,但强迫症忍不了 以下是解决办法 Let's do it ... 进入设置,找到Console下的Python Cons ...

  5. Java核心技术及面试指南 流程控制方面的面试题答案

    2.2.5.1 switch语句能否作用在byte上,能否作用在long上,能否作用在String上? 1 switch里可以用char,byte,short,int这些基本类型,以及它们的封装类.  ...

  6. 微信小程序onLaunch异步,首页onLoad先执行?

    本来按照事件顺序,小程序初始化时触发App里的onLaunch,后面再执行页面Page里的onLoad,但是在onLaunch里请求获取是否有权限,等待返回值的时候Page里的onLoad事件就已经执 ...

  7. 西安活动 | 9月15号 "拥抱开源, 又见.NET" 线下交流活动

    随着.NET Core的发布和开源,.NET又重新回到了人们的视野.除了开源.跨平台.高性能以及优秀的语言特性,越来越多的第三方开源库也出现在了github上——包括ML.NET机器学习.Xamari ...

  8. socket的阻塞与非阻塞,同步与异步

    同步/异步主要针对C端: 同步:      所谓同步,就是在c端发出一个功能调用时,在没有得到结果之前,该调用就不返回.也就是必须一件一件事做,等前一件做完了才能做下一件事. 例如普通B/S模式(同步 ...

  9. C#.Net Core 操作Docker中的redis数据库

    做软件开发的人,会在本机安装很多开发时要用到的软件,比如数据库,有MS SQL Server,MySQL,等,如果每种数据库都按照在本机确实有点乱,这个时候我们就想用虚拟机来隔离,这样就不会扰乱本机一 ...

  10. 自定义了一个email模块,符合大多数人的使用习惯

    # coding: utf-8 import smtplib from email.mime.multipart import MIMEMultipart from email.mime.text i ...