js数据结构之列表的详细实现方法
* 列表用于存放数据量较少的数据结构
* 当数据量较大时,不需要对其进行查找、排序的情况下,使用列表也比较方便。
本数据结构在node环境下运行,需要对node有个基本是了解。
1. listSize: 列表长度
2. pos 当前位置
3. getLength 获取列表的长度
4. toString 返回列表的字符串
5.getElement 获取当前位置的元素
6. insert 在指定位置的后面插入
7. append 在列表的末尾插入
8. remove 删除元素
9.front 把当前位置移到首位
10 end 把当前位置移到末尾
11. prev 把当前位置前移一位
12. next 把当前位置后移一位
13. currentPos 获取当前位置
14 moveTo 把当前位置移动到指定位置
15 find 找到指定的元素
16 loop 列表的遍历器(index为索引,loopItem为对应的元素)
下面通过fs模块将制定txt文档中的内容装进列表中:
列表对象数据如下:
function List () {
this.listSize = 0; // 列表长度
this.pos = 0; // 当前位置
this.clear = clear; // 清空列表
this.getLength = getLength; // 获取列表的长度
this.toString = toString; // 返回列表的字符串形式
this.getElement = getElement; // 返回当前位置的元素
this.insert = insert; //在当前位置元素的后面插入元素
this.append =append; // 在列表的末尾添加元素
this.remove = remove; // 从列表中删除当前元素
this.front = front; // 将列表的当前位置移动到第一个元素位置
this.end =end; // 将列表的当前位置移动到最后一个元素位置
this.prev = prev; // 将列表的当前位置向前移动一位
this.next = next; // 将列表的当前位置向后移动一位
this.currentPos = currentPos; // 返回列表的当前位置
this.moveTo = moveTo; // 将当前位置移动到指定位置
this.find = find; // 获取指定元素的位置
this.loop = loop; // 列表的遍历器
this.list = [];
function clear () {
this.list.length = 0;
this.listSize = 0;
this.pos = 0;
}
function getLength () {
return this.list.length;
}
function toString () {
return this.list;
}
function getElement () {
return this.list[this.pos];
}
function insert (item, after) {
var index = this.find(after)
if(index){
this.list.splice(index+1, 0, item);
this.listSize++;
return 1;
}
return -1
}
function append (item) {
this.list.push(item);
this.listSize++;
}
function remove (ele) {
for (var i=0; i<this.list.length; i++) {
console.log(this.list[i]);
if(this.list[i]==ele){
this.list.splice(i, 1);
console.log("remove");
return 1;
}
}
console.log("not remove");
this.listSize--;
return -1;
}
function front () {
this.pos = 0;
}
function end () {
this.pos = this.list.length-1;
}
function prev () {
this.pos--;
}
function next () {
this.pos++;
}
function currentPos () {
return this.pos;
}
function moveTo (index) {
this.pos = index;
}
function find (ele) {
for (var i = 0; i<this.list.length; i++) {
if(this.list[i] == ele) {
return i
}
}
return -1;
}
function loop (cb) {
for(this.front();this.currentPos()<this.list.length;this.next()){
var loopItem = this.getElement();
var index = this.currentPos();
(function(index, loopItem){
cb(index, loopItem);
})(index, loopItem)
}
}
}
.txt文件如下:
(1) The Shawshank Redemption(《肖申克的救赎》)
(2) The Godfather(《教父》)
(3) The Godfather: Part II(《教父2》)
(4) Pulp Fiction(《低俗小说》)
(5) The Good, the Bad and the Ugly(《黄金三镖客》)
(6) 12 Angry Men(《十二怒汉》)
(7) Schindler’s List(《辛德勒名单》)
(8) The Dark Knight(《黑暗骑士》)
(9) The Lord of the Rings: The Return of the King(《指环王:王者归来》)
(10) Fight Club(《搏击俱乐部》)
(11) Star Wars: Episode V - The Empire Strikes Back(《星球大战5:帝国反击战》)
(12) One Flew Over the Cuckoo’s Nest(《飞越疯人院》)
(13) The Lord of the Rings: The Fellowship of the Ring(《指环王:护戒使者》)
(14) Inception(《盗梦空间》)
(15) Goodfellas(《好家伙》)
(16) Star Wars(《星球大战》)
(17) Seven Samurai(《七武士》)
(18) The Matrix(《黑客帝国》)
(19) Forrest Gump(《阿甘正传》)
(20) City of God(《上帝之城》)
利用fs读取后将每一项装入列表中:
const fs = require("fs");
var listData = fs.readFileSync("movie.txt", "utf-8").split("\r\n");
listData.forEach(function(item){
movieList.append(item);
})
js数据结构之列表的详细实现方法的更多相关文章
- js数据结构之集合的详细实现方法
数据结构中的集合,类似于数学中常说的集合,是一类数据的群组.集合与集合之间还存在交集,并集,补集的运算. ***集合为无序,集合内元素不重复 ***js的set基于数组, 使用SetClass为类名, ...
- js数据结构之二叉树的详细实现方法
数据结构中,二叉树的使用频率非常高,这得益于二叉树优秀的性能. 二叉树是非线性的数据结构,用以存储带有层级的数据,其用于查找的删除的性能非常高. 二叉树 数据结构的实现方法如下: function N ...
- 如何发布一个自定义Node.js模块到NPM(详细步骤,附Git使用方法)
咱们闲话不多说,直接开始! 由于我从没有使用过MAC,所以我不保证本文中介绍的操作与MAC一致. 文章开始我先假定各位已经在window全局安装了Node.js,下面开始进行详细步骤介绍: 本文本着, ...
- JS数据结构的栈和队列操作
数据结构:列表.栈.队列.链表.字典.散列.图和二叉查找树! 排序算法:冒牌.选择.插入.希尔.归并和快速! 查找算法:顺序查找和二分查找 在平时工作中,对数组的操作很是平常,它提供了很多方法使用,比 ...
- JS数据结构之 Map
JS数据结构之 Map Map介绍 Map(映射)是ES6引入的一种数据结构.这是一种存储键值对列表很方便的方法,类似于其他编程语言的哈希表. HashMap(哈希表),也叫做散列表.是根据关键码值 ...
- C#开发微信门户及应用(4)--关注用户列表及详细信息管理
在上个月的对C#开发微信门户及应用做了介绍,写过了几篇的随笔进行分享,由于时间关系,间隔了一段时间没有继续写这个系列的博客了,并不是对这个方面停止了研究,而是继续深入探索这方面的技术,为了更好的应用起 ...
- PHP函数可变参数列表的具体实现方法介绍
PHP函数可变参数列表可以通过_get_args().func_num_args().func_get_arg()这三个函数来实现.我们下面就对此做了详细的介绍. AD:2014WOT全球软件技术峰会 ...
- 如何发布一个自定义Node.js模块到NPM(详细步骤)
咱们闲话不多说,直接开始! 由于我从没有使用过MAC,所以我不保证本文中介绍的操作与MAC一致. 文章开始我先假定各位已经在window全局安装了Node.js,下面开始进行详细步骤介绍: 本文本着, ...
- jquery jtemplates.js模板渲染引擎的详细用法第三篇
jquery jtemplates.js模板渲染引擎的详细用法第三篇 <span style="font-family:Microsoft YaHei;font-size:14px;& ...
随机推荐
- HDU 6158 笛卡尔定理+韦达定理
The Designer Time Limit: 8000/4000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Tota ...
- Python3.x文件处理详解
Python3.x文件处理详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 任何一门语言都有其特有的操作文件的方式,Python2.x版本有两种操作文件的方式,没错就是open函 ...
- SQL记录-PLSQL函数
PL/SQL函数 PL/SQL函数与过程相同,不同之处在于函数有一个返回值.因此,前面的章节中的所有讨论都适用于函数. 创建函数 建立一个独立函数可以使用CREATE FUNCTION语句创建.CRE ...
- JIRA项目管理搭建
部署JIRA 7.2.2 for Linux 转自:http://www.yfshare.vip/2017/05/09/%E9%83%A8%E7%BD%B2JIRA-7-2-2-for-Linux/ ...
- 【DS】排序算法之快速排序(Quick Sort)
一.算法思想 快速排序,顾名思义,效率比较于其他算法,效率比较高.<算法导论>也专门对其进行讲解.其算法设计使用分治思想,如下: 1)从数组A[p...r]中选择一个元素,将数组划分成两个 ...
- 一些javascript的工具书
http://pan.baidu.com/s/1jGj9CvO
- AngularJs -- ngMessages(1.3+)
ngMessages(1.3+) 表单和验证是AngularJS中复杂的组件之一.用AngularJS默认的方式来写,不是特别好,不简洁. 在AngualrJS1.3发布前,表单验证必须以这种方式编写 ...
- 002_tmux详解
参考下赖老师的: http://mingxinglai.com/cn/2012/09/tmux/ 一. 二. http://wdxtub.com/2016/03/30/tmux-guide/ (待 ...
- 【前端开发】关于闭包最通俗易懂的解释 for循环,定时器,闭包混合一块的那点事。
for循环,定时器,闭包混合一块的那点事. 1,对于一个基本的for循环,顺序输出变量值. for(var i = 1; i < 4; i++){ console.log(i);//结果不多说了 ...
- NOIp 2018 提高组
T1铺设道路 传送门 题目描述 春春是一名道路工程师,负责铺设一条长度为 $ n $ 的道路. 铺设道路的主要工作是填平下陷的地表.整段道路可以看作是 $ n $ 块首尾相连的区域,一开始,第 ii ...