js实现个链表吧
存储多个元素,最常用的数据结构是数组。但是数组有个一缺点,从数组中添加或移除项的成本很高,因为需要移动元素。链表也可以存储有序的元素集合,但是和数组不同,链表中的元素在内存中不是连续放置的。每个元素存储本身节点值和下一个元素的引用,链表的一个好处在于,添加或移除元素的时候不需要移动其他元素。
ok,开始实现我们的数据结构,骨架如下
function LinkedList() {
var Node = function (val) {
this.val = val;
this.next = null;
}; //Node辅助类
var length = 0;
var head = null;
this.append = function (ele) {}; //追加
this.insert = function (pos, ele) {}; //插入
this.removeAt = function (pos) {}; //移除
this.indexOf = function (ele) {}; //查找元素
this.isEmpty = function () {}; //是否为空
this.size = function () {}; //链表元素个数
this.getHead = function () {}; //链表头
this.toString = function () {}; //转换为字符串
}
首先实现向链表尾部追加元素吧:
this.append = function (ele) {
var node = new Node(ele),
current;
if (head == null) {
head = node;
} else {
current = head;
//找到最后一项
while (current.next) {
current = current.next;
}
//将最后一项的next指向 node
current.next = node;
}
length++; //更新链表长度
}
继续实现链表插入
this.insert = function (pos, ele) {
var node = new Node(ele);
var idx = 0,
previous,
current = head;
// 检查是否越界
if (pos >= 0 && pos <= length) {
if (pos === 0) {
node.next = current;
head = node;
} else {
while (idx < pos) {
previous = current; //保存前一个节点的引用
current = current.next;
idx++;
}
node.next = current; //节点的next指向current
previous.next = node; //前一个节点指向node
length++; //更新数组长度
}
} else {
return false;
}
}
链表的移除:
this.removeAt = function (pos) {
var current = head;
var idx = 0,
previous;
//检查越界
if (pos >= 0 && pos <= length) {
if (pos === 0) {
head = current.next;
} else {
while (idx < pos) {
previous = current;
current = current.next;
idx++;
}
previous.next = current.next; //前一个节点指向下一个节点
}
length--; //更新链表长度
return current.val;
} else {
return null
}
}
其他方法就比较简单了,实现如下:
this.isEmpty = function () {
return !length;
}
this.size = function () {
return length;
}
this.getHead = function () {
return head;
}
this.toString = function () {
var str = '';
var current = head;
while (current) {
str = str + ',' + current.val;
current = current.next;
}
return str.slice(1);
}
js实现个链表吧的更多相关文章
- JS实现单链表、单循环链表
链表 链表是一种物理存储单元上非线性.非连续性的数据结构(它在数据逻辑上是线性的),它的每个节点由两个域组成:数据域和指针域.数据域中存储实际数据,指针域则存储着指针信息,指向链表中的下一个元素或者上 ...
- 原生JS实现单向链表
1.前言 用JS实现一个简单的单向链表,并完成相关的功能 2.功能说明 push(value):从链表尾部添加一个新的节点 insertAfer(value,item):向链表中的item节点之后插入 ...
- 用js对象创建链表
//以下是一个链表类 function LinkedList(){ //Node表示要加入列表的项 var Node=function(element){ this.element=element; ...
- js 实现数据结构 -- 链表
原文: 在 Javascript 中学习数据结构与算法. 概念: 链表存储有序的元素集合,但不同于数组,链表中的元素在内存中并不是连续放置的.每个 元素由一个存储元素本身的节点和一个指向下一个元素的引 ...
- js数据结构之链表(单链表、双向链表、循环链表)
首先,链表有以下特点: 1. 存储空间不固定,可灵活扩充 2.方便多次的插入和删除,效率较高 单链表 单链表是最常用的链表,其对数据的操作均为单项的,向后查找的. /* 链表(基于对象) 此处为单链表 ...
- JS实现单向链表、双向链表、循环链表
https://cloud.tencent.com/developer/article/1114246 链表存储有序的元素的集合,但是和数组不同的是,链表中的元素在内存中的存储并不是连续的.每一个链表 ...
- 单链表、循环链表的JS实现
数据结构系列前言: 数据结构作为程序员的基本知识,需要我们每个人牢牢掌握.近期我也展开了对数据结构的二次学习,来弥补当年挖的坑...... 当时上课的时候也就是跟着听课,没有亲自实现任何一种数据结 ...
- 用js来实现那些数据结构07(链表01-链表的实现)
前面讲解了数组,栈和队列.其实大家回想一下.它们有很多相似的地方.甚至栈和队列这两种数据结构在js中的实现方式也都是基于数组.无论增删的方式.遵循的原则如何,它们都是有序集合的列表.在js中,我们新建 ...
- js数据结构与算法--单链表的实现与应用思考
链表是动态的数据结构,它的每个元素由一个存储元素本身的节点和一个指向下一个元素的引用(也称指针或链接)组成. 现实中,有一些链表的例子. 第一个就是寻宝的游戏.你有一条线索,这条线索是指向寻找下一条线 ...
随机推荐
- Python3 tesseract加载chi_sim异常停止工作
Python3 tesseract加载chi_sim异常停止工作 原因: chi_sim.traineddata 和 tesseract3.0.2 版本不一致: 解决方案: 下载tesseract3. ...
- log4j.properties配置详解与实例
log4j.properties配置详解与实例 第一步:加入log4j-1.x.x.jar到lib下. 第二步:在工程的src下下建立log4j.properties.内容如下: #OFF,syste ...
- 20145334赵文豪《网络攻防》 MSF基础应用
实践目标 掌握metasploit的基本应用方式 掌握常用的三种攻击方式的思路. 实验要求 一个主动攻击,如ms08_067 一个针对浏览器的攻击,如ms11_050 一个针对客户端的攻击,如Adob ...
- Android Studio导入包
1.复制jar包,打开工程,以project形式打开,在libs下面粘贴: 2.右键jar包,add as library.
- Centos7.2 安装Elasticsearch 6
下载 elasticsearch.6.0.0.tar.gz 迁移文件到usr/local中 mv elasticsearch-.tar.gz /usr/local/ cd /usr/local tar ...
- Is it bad to rely on foreign key cascading? 外键 级联操作
Is it bad to rely on foreign key cascading? I'll preface前言 this by saying that I rarely delete rows ...
- 以QQ举例 说明计算机网络中的一些概念区别(TCP与UDP,广播与单播)
QQ 中的 广播与单播 今天简单地学习了一下 广播和多播(组播) 的知识.关于 单播和多播 的概念,可以用 QQ 中的一些例子来解释. 单播,就像 两个人聊QQ 一样,信息的接收和传递只在两个节点之间 ...
- 树莓派GPIO
- HDU 3549 Flow Problem(最大流模板)
http://acm.hdu.edu.cn/showproblem.php?pid=3549 刚接触网络流,感觉有点难啊,只好先拿几道基础的模板题来练练手. 最大流的模板题. #include< ...
- C++ Boost在VS2015中的使用
1.下载包 目录结构: 切换到上面的目录,然后运行 bootstrap.bat 执行完毕后会生成两个exe文件 继续执行 bjam.exe 结束后,目录如下 2.设置路径 测试 #include &q ...