JavaScript--数据结构与算法之列表
3.1 列表的抽象数据类型定义
列表:一组有序的数据。每个列表中的数据称为元素。在JavaScript中列表的元素可以是任意的数据类型。列表中保存的元素没有事先的限定,实际使用时的元素数量受到程序内存的限制。
属性:
listSize: 列表的元素个数
pos: 列表的当前位置
length: 返回列表中元素的个数
方法:
clear(): 清空列S表中的所有元素
toString(): 返回列表的字符串形式
getElement(): 返回当前位置的元素
insert(): 现有元素后插入新元素
append(): 在列表的末尾添加一个元素
remove(): 从列表中移除元素
front(): 从列表的当前位置移动到第一个位置
end(): 从列表的当前位置移动到最后一个位置
prev(): 当前位置后移一位
next(): 当前位置前移一位
currPos(): 返回列表的当前位置
moveTo(): 将当前位置移动到指定位置
创建List列表,及扩展属性方法:
function List() {
this.listSize = 0;
this.pos = 0;
this.dataStore = [];
//面向对象方法不在初始化中,这里只初始化属性
//this.clear = clear;
//this.toString = toString;
//this.insert = insert;
//this.append = append;
//this.remove = remove;
//this.front = front;
//this.end = end;
//this.prev = prev;
//this.currPos = currPos;
//this.moveTo = moveTo;
//this.length = length;
}
//append()方法在列表的末尾插入一个元素:
List.prototype.append = function(element) {
this.dataStore[this.listSize++] = element;
}
//插入的元素赋值给dataStore,同时改变对应的下标;
//find()找到列表中所对应的元素:通过遍历dataStore中的元素,匹配元素是否相等,如果是返回对应的下标,如果不是返回-1;
List.prototype.find = function(element) {
for(var i = 0; i < dataStore.length; i++) {
if(this.dataStore[i] == element) {
return i;
}
}
return -1;
}
//remove()移除列表中的元素:
//首先通过find()方法把所要删除的元素找到,如果存在所要删除的元素,利用数组splice();方法删除,同时listSize列表元素个数减一,删除成功返回true;失败返回false;
List.prototype.remove = function(element) {
var findElement = this.find(element);
if( findElement > -1) {
this.dataStore.splice(findElement,1);
this.listSize--;
return true;
}
return false;
}
//length: 列表length,返回元素的个数
List.prototype.length = function() {
return this.listSize;
}
//toString()显示列表中的元素
List.prototype.toString = function() {
return this.dataStore;
}
//insert()项列表中插入一个元素:
//接受两个参数,一个是插入的元素,一个是插入的位置。该方法使用find()方法找到对应的元素,通过判断该元素是否存在,如果不存在在进行插入操作,不存在则通过数组的splice()方法进行插入,同时改变list列表的元素个数。成功返回true,失败返回false;
List.prototype.insert = function(element,after) {//插入元素,插入位置(从0开始)
var insertPos = this.find(after);
if(insertPos > -1) {
this.dataStore.splice( insertPos+1,0,element );//pos+1数组下标从0开始
this.listSize++;
return true;
}
return false;
}
//clear()清空列表中的所有元素:
//该方法通过delete删除dataStore数组,重新创建空的新数组,然后把list列表的元素个数,当前位置改为0;
List.prototype.clear = function() {
delete this.dataStore;
this.dataStore = [];
this.listSize = this.pos = 0;
}
//contains()判断给定值是否在list列表中
//该方法和find()方法类似,contains方法包含返回true,不包含返回false,find方法查找到该元素,返回该元素的下标,不存在返回-1。
List.prototype.contains = function(element) {
for(var i = 0; i < this.dataSize.length; i++) {
if( this.dataStore[i] == element ) {
return true;
}
}
return false;
}
JavaScript--数据结构与算法之列表的更多相关文章
- javascript数据结构与算法---列表
javascript数据结构与算法---列表 前言:在日常生活中,人们经常要使用列表,比如我们有时候要去购物时,为了购物时东西要买全,我们可以在去之前,列下要买的东西,这就要用的列表了,或者我们小时候 ...
- 为什么我要放弃javaScript数据结构与算法(第七章)—— 字典和散列表
本章学习使用字典和散列表来存储唯一值(不重复的值)的数据结构. 集合.字典和散列表可以存储不重复的值.在集合中,我们感兴趣的是每个值本身,并把它作为主要元素.而字典和散列表中都是用 [键,值]的形式来 ...
- JavaScript数据结构与算法-列表练习
实现列表类 // 列表类 function List () { this.listSize = 0; // 列表的元素个数 this.pos = 0; // 列表的当前位置 this.dataStor ...
- javascript数据结构与算法--高级排序算法
javascript数据结构与算法--高级排序算法 高级排序算法是处理大型数据集的最高效排序算法,它是处理的数据集可以达到上百万个元素,而不仅仅是几百个或者几千个.现在我们来学习下2种高级排序算法-- ...
- javascript数据结构与算法-- 二叉树
javascript数据结构与算法-- 二叉树 树是计算机科学中经常用到的一种数据结构.树是一种非线性的数据结构,以分成的方式存储数据,树被用来存储具有层级关系的数据,比如文件系统的文件,树还被用来存 ...
- javascript数据结构与算法--散列
一:javascript数据结构与算法--散列 一:什么是哈希表? 哈希表也叫散列表,是根据关键码值(key,value)而直接进行访问的数据结构,它是通过键码值映射到表中一个位置来访问记录的,散列 ...
- javascript数据结构与算法---队列
javascript数据结构与算法---队列 队列是一种列表,不同的是队列只能在队尾插入元素,在队首删除元素.队列用于存储按顺序排列的数据,先进先出,这点和栈不一样(后入先出).在栈中,最后入栈的元素 ...
- javascript数据结构与算法---栈
javascript数据结构与算法---栈 在上一遍博客介绍了下列表,列表是最简单的一种结构,但是如果要处理一些比较复杂的结构,列表显得太简陋了,所以我们需要某种和列表类似但是更复杂的数据结构---栈 ...
- javascript数据结构与算法---检索算法(顺序查找、最大最小值、自组织查询)
javascript数据结构与算法---检索算法(顺序查找.最大最小值.自组织查询) 一.顺序查找法 /* * 顺序查找法 * * 顺序查找法只要从列表的第一个元素开始循环,然后逐个与要查找的数据进行 ...
- 为什么我要放弃javaScript数据结构与算法(第十章)—— 排序和搜索算法
本章将会学习最常见的排序和搜索算法,如冒泡排序.选择排序.插入排序.归并排序.快速排序和堆排序,以及顺序排序和二叉搜索算法. 第十章 排序和搜索算法 排序算法 我们会从一个最慢的开始,接着是一些性能好 ...
随机推荐
- 函数指针的转换 & C的注意点
再让我们看看<signal.h>中声明的signal函数void (*signal(int, void(*)(int)))(int)首先,用typedef简化,typedef void ( ...
- JSunpack-n模拟WireShark拦截文件传输
前言: 在前面的实验里我们进行了JSunpack-n的安装及其简单使用.JSunpack-n还有另外一些功能须要进行測试试验,由于本人也是刚接触这些东西.本文就当中一个"功能点"进 ...
- 习题(3-3) 计算(a+b)*c的值
题目 - 习题(3-3) 计算(a+b)*c的值 来源 计算概论B 2010 描写叙述 计算表达式(a+b)*c的值,当中a, b, c均为整数,且a,b,c的值介于-10000和10000之间( ...
- ListView阻尼效果
效果图省略.. . activity_main.xml(仅仅有一个自己定义ListView) <RelativeLayout xmlns:android="http://schemas ...
- BZOJ 2730 矿场搭建 Tarjan求割点
思路: Tarjan求出来点双&割点 判一判就行了 //By SiriusRen #include <stack> #include <cstdio> #include ...
- Android CardView卡片布局 标签: 控件
CardView介绍 CardView是Android 5.0系统引入的控件,相当于FragmentLayout布局控件然后添加圆角及阴影的效果:CardView被包装为一种布局,并且经常在ListV ...
- HTTP协议学习,post于get;用Fiddler测试请求
转载 收藏于网络 1.简介: HTTP协议:Hypertext transfer protocol 超文本 传输 协议 它是TCP/IP协议集中的一个运用层协议. 用于定义WEB浏览器和WEB服务器之 ...
- Visual studio 之常见编译错误(1):syntax error : missing ';' before identifier 'PVOID64'
来自博客:http://blog.csdn.net/chenyusiyuan/article/details/4643313的总结: 一般可通过调整 DirectShow/Include 在 Tool ...
- 关于idea开发工具常用的快捷键
自动补全缺失的import alt+enter 自动优化import ctrl+alt+o 自动补全返回代码:IDEA的ctrl+alt+v ,eclipse的CTRL+F1 main p ...
- 如何形象的解释 webhook 这个词
就是一个 callback,只不过 callback 的操作是发送指定的 HTTP request 给一个指定的地址. callback 就是由甲传给乙,乙处理完之后通知甲传过来的方法或者请求甲方的 ...