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

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

        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. SQL Server对比两字符串的相似度(函数算法)

    一.概述    最近有人问到关于两个字符串求相似度的函数,所以就写了本篇文章,分别是“简单的模糊匹配”,“顺序匹配”,“一对一位置匹配”.在平时的这种函数可能会需要用到,业务需求不一样,这里只给出参照 ...

  2. Java垃圾回收概览

    GC要解决三个主要的问题: 哪些内存需要回收? 什么时候回收? 如何回收? 哪些内存需要回收? 最简单的是引用计数(reference count),缺陷是无法解决循环引用.于是更快点的算法是可达性分 ...

  3. MVC详解

    模型-视图-控制器(Modal View Controler,MVC)是Xerox PARC在八十年代为编程语言Smalltalk-80发明的一种软件设计模式,至今已被广泛使用.最近几年被推荐为Sun ...

  4. 如何利用sqoop将hive数据导入导出数据到mysql

    运行环境  centos 5.6   hadoop  hive sqoop是让hadoop技术支持的clouder公司开发的一个在关系数据库和hdfs,hive之间数据导入导出的一个工具. 上海尚学堂 ...

  5. Android JNI 学习(三):JNI 数据类型和数据结构

    本文我们来讨论一下JNI如何将Java类型映射到本机C类型. 一.基本数据类型 如下图表整理了Java基本类型和native对应的关系: Java类型 Native类型 描述 boolean jboo ...

  6. 怎么随时获取Spring的上下文ApplicaitonContext,和Spring管理的Bean

    BeanFactory接口 Interface BeanFactory getBean <T> T getBean(String name, Class<T> required ...

  7. 微信小程序我的界面

    前言 感谢! 承蒙关照~ 微信小程序我的界面 界面效果: 界面结构: 小程序代码: 我们先看me.json代码 { "navigationBarTitleText": " ...

  8. 2个简单实例让你快速理解try-catch的用法

    相信在实际项目中,你可能经常会看到类似下面的代码 try { // 尝试执行代码块 } catch(err) { // 捕获错误的代码块 } finally { // 结果如何都会执行的代码块 } 简 ...

  9. LabVIEW(五):DAQ同步

    1.在许多的测试测量应用当中,我们会需要在通过一个时间段内进行同步测量. 同步采集通常分为两类: (1).同时测量:即不同的任务在同一时刻开始.举例来说,我们会在一个模拟输入通道上采集数据,同时在一个 ...

  10. jQuery文档操作

    jQuery文档操作 1.jq文档结构 var $sup = $('.sup'); $sup.children(); // sup所有的子级们 $sup.parent(); // sup的父级(一个, ...