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数据结构与算法--单链表的实现与应用思考
链表是动态的数据结构,它的每个元素由一个存储元素本身的节点和一个指向下一个元素的引用(也称指针或链接)组成. 现实中,有一些链表的例子. 第一个就是寻宝的游戏.你有一条线索,这条线索是指向寻找下一条线 ...
随机推荐
- CSS 基础知识点 样式 选择器 伪类
CSS 基础知识点汇集 版权声明:这篇博客是别人写的,大神博客地址 : https://www.cnblogs.com/Mtime/p/5184685.html 1.CSS 简介 CSS 指层叠样式表 ...
- 谈谈java中的final关键字
知识点:final(最终的)关键字修饰类.方法.属性 1.final修饰类:那么这个就无法被继承,如String类.StringBuffer类.System类 2.final修饰方法:被修饰的方法不能 ...
- springBoot 打包 dubbo jar包
参看链接:http://blog.csdn.net/cqdz_dj/article/details/51942681 http://blog.csdn.net/u014695188/art ...
- 02_Flume1.6.0安装及单节点Agent实践
Flume1.6.0的安装1.上传Flume-1.6.0-tar.gz到待部署的所有机器 以我的为例: /usr/local/src/ 2.解压得到flume文件夹 # tar -x ...
- 微信网页跳转页面常见bug处理
微信网页跳转页面常见bug处理 1.不要直接用a链接直接跳转 2.url后加上时间戳 function gohome() { window.location.href = "../home/ ...
- TCGA系列--LncMAP
LncMAP:http://www.bio-bigdata.com/LncMAP/index.jsp
- 提高Intellij创建Maven工程的速度
按照默认的方式创建Maven工程的时候会发现Maven插件加载的很慢如下 解决方法:在创建的过程中,在Properties中添加一个参数archetypeCatalog=internal . 因为ar ...
- HHVM代码规范
原文戳我 本文旨在为HHVM编写C++代码提供一种指南,包括了什么时候.怎么使用各种语言功能,以及代码的格式.我们的目标是确保代码持续高可用的同时,还能容易被阅读和参与贡献,尤其是对新人而言. HHV ...
- stack_01
A.添加/移除 A.1.void stack::push(elemValue); // 栈头 添加元素 A.2.void stack::pop(); // 栈头 移除第一个元素 B.随机存取 C.数据 ...
- Qt for Embedded Linux
1. Qt for Embedded Linux http://doc.qt.io/qt-5/embedded-linux.html 2. Installing Qt for Embedded Lin ...