前言

数据结构就是关系,没错,就是数据元素相互之间存在的一种或多种特定关系的集合。
常用的数据结构有:
数组,队列(queue),堆(heap),栈(stack),链表(linked list ),树(tree),图(graph)和散列表(hash)
本文主要介绍的是数组、栈与队列,下面来一起看看详细的介绍吧。
一、数组
数组是平时使用最常用的数据结构,在JavaScript中数组是动态的分配大小,在这里我不会介绍JavaScript里面数组的所有的方法,而是针对数据结构这个方向谈谈所用到的方法。
创建和初始化数组
//创建空数组 var array = new Array(); //[] //初始化数组 var array = new Array(1,2,3); var array = Array.of(1,2,3);//ES6的方法 //[1,2,3] //创建大小为5的数组 var array = new Array();//ES6的方法 //[undefined,undefined,undefined,undefined,undefined] //给数组赋值 var array = new Array(); array[0] = 1 ; array[1] = 2 ; array[2] = 3 ; //[1,2,3]
添加元素
往数组后添加元素
var number = [1,2,3]; number[number.length] = 4; //[1,2,3,4] //或者 var number = [1,2,3]; number.push(4); //[1,2,3,4]
往数组前面添加元素
var number = [1,2,3]; number.unshift(0); //[0,1,2,3] number.unshift(-2,-1); //[-2,-1,0,1,2,3]
往数组的任意位置插入元素
运用splice方法
//在索引1后面添加2,3,4 var number = [1,5,6]; number.splice(1,0,2,3,4); //[1,2,3,4,5,6]
删除元素
删除第一位
var number = [1,2,3]; number.shift(); //[2,3]
删除任意位置
使用splice方法删除数组任意位置的元素
var numebr = [1,2,3,4,5,6]; //如果想删除元素3 number.splice(2,1); //[1,2,4,5,6] //如果想删除元素4,5 number.splice(3,2);
排序
反序
var number = [3,2,1]; number.reverse(); //[1,2,3]
自然排序
var numebr = [2,3,4,1,3,7]; number.sort(); //[1,2,3,3,4,7]
自定义排序
这个自定义排序跟java里面实现comparator接口一个意思。用处可大了。
var number = [4,5,6,7,1,2,3,8,9,10,11,12,13]; number.sort(); //[1, 10, 11, 12, 13, 2, 3, 4, 5, 6, 7, 8, 9]
仿佛看起有点不对啊,我们应该想要的是
[1,2,3,4,5,6,7,8,9,10,11,12,13],这个时候我们就用自定义排序来解决这个问题
var number = [4,5,6,7,1,2,3,8,9,10,11,12,13];
function compare(a,b){
if(a < b){
return -1;
}
if(a > b){
return 1;
}
return 0;
}
number.sort(compare);
//[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13]
这还只是最简单的,也可以对任何对象类型进行数组排序。例如,对象Person有名字和年龄属性,我们希望根据年龄排序
var friends = [{name:'李晨',age:40},{name:'范冰冰',age:35}];
function comparePerson(a,b){
if(a.age < b.age){
return -1;
}
if(a.age > b.age){
return 1;
}
return 0;
}
friends.sort(comparePerson);
//[{name:'范冰冰',age:35},{name:'李晨',age:40}]
搜索
搜索有两个方法:indexOf方法返回与参数匹配的第一个元素的索引,lastIndexOf返回与参数匹配的最后一个元素的索引。
var number = [1,3,4,3,56,6,7,4]; number.indexOf(3);//1 number.lastIndexOf(3)//3
二、栈
栈是一种遵循后进先出(LIFO)原则的有序集合。新添加的或待删除的元素都保存在栈的末尾,称作栈顶,另一端就叫栈底。在栈里,新元素都靠近栈顶,旧元素都接近栈底。在JavaScript中变量保存和函数调用都是用栈存储的。
首先创建一个类来表示一个栈,需要一种数据结构来保存栈里的元素。这里我们就选择刚学的数组:var items = [];
接下来,为我们的栈声明一些方法:
push(elements(s)) :添加一个(或几个)新元素到栈顶pop() :移除栈顶的元素,同时返回被移除的元素peek() :获取栈顶的元素,不对栈做出任何修改isEmpty() :如果栈里没有任何元素就返回true,否则返回false;clear() :清空栈size() :返回栈元素的个数如果上一节数组认真看了,我相信用JavaScript实现一个栈是非常简单的。在这里就直接来代码了,不用一个方法一个方法去解释了。
function Stack(){
var items = [];
this.push = function(element){
items.push(element);
}
this.pop = function(){
return items.pop();
}
this.peek = function(){
return items[items.length-1];
}
this.isEmpty = function(){
return items.length === 0;
}
this.size = function(){
return items.length;
}
this.clear = function(){
items = [];
}
this.print = funciton(){
console.log(items.toString());
}
}
三、队列
队列是遵循先来先服务(FIFO)原则的一组有序的项。队列在尾部添加新元素,并从顶部移除元素。最新添加的元素排在队列的末尾。
在现实生活中常见的例子就是排队。
在计算机科学中,一个常见的例子就是打印队列,先点击打印的文档会被先打印。
创建队列
同样先创建一个类来表示一个队列。需要用到的数据结构同样是数组var items = [];
声明可用的方法:
enqueue(element(s)) :向队尾添加一个(或多个)新的项dequeue() :移除队列的第一(即排在队列最前面的)项,并返回被移除的元素。front() :返回队列中第一个元素isEmpty() :如果队列中不包含元素返回true,否则返回falsesize() :返回队列包含元素的个数完整的Queue类
function Queue(){
var items = [];
this.enqueue = function(element){
items.push(element);
}
this.dequeue = function(){
return items.shift();
}
this.front = function(){
return items[0];
}
this.isEmpty = function(){
return items.length === 0;
}
this.clear = function(){
items = [];
}
this.size = funciton(){
return items.length;
}
this.print = function(){
console.log(items.toString());
}
}
优先队列
在优先队列中,元素被赋予优先级。当访问元素的时,具有最高优先级的元素先删除。优先队列具有最高进先出的行为特征。例如:医院的急救室为病人赋予优先级(这个优先级可以指病情严重的成程度),具有最高优先级的病人最先得到治疗。
实现一个优先队列有两种选项:
我们这里采用第一种。
function PriorityQueue(){
var items = [];
funciton QueueElement(element,priority){
this.element = element;
this.priority = priority;
}
function comparePriority(a,b){
if(a.priority > b.priority){
return 1;
}
if(a.priority < b.priority){
return -1;
}
return 0;
}
this.enqueue = funciton(element,priority){
var queueElement = new QueueElement(element,priority);
items.push(queueElement);
items.sort(comparePriority);
}
//其它方法和默认的Queue实现相同
}
当然,这个enqueue的实现方法很多种,我这效率不是最高的,但是容易理解。将插入的元素根据优先级排个序,那么先出去的就是优先级最高的了。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
# js
# 栈和队列
# 数组队列
# 数组
# 栈
# 深入JavaScript高级程序设计之对象、数组(栈方法
# 队列方法
# 重排序方法
# 迭代方法)
# JavaScript数据结构与算法之栈与队列
# JS实现队列与堆栈的方法
# JavaScript数组实现数据结构中的队列与堆栈
# JavaScript数组的栈方法与队列方法详解
# JS实现利用两个队列表示一个栈的方法
# JavaScript栈和队列相关操作与实现方法详解
# JavaScript基于数组实现的栈与队列操作示例
# 如何使用JavaScript实现栈与队列
# JavaScript中栈和队列应用详情
# 数据结构
# 移除
# 自定义
# 的是
# 在这里
# 第一个
# 排在
# 创建一个
# 都是
# 几个
# 是一种
# 看了
# 多个
# 没有任何
# 我这
# 也可
# 我不会
# 相互之间
# 这个时候
# 大了
相关文章:
番禺网站制作公司哪家值得合作,番禺图书馆新馆开放了吗?
如何通过主机屋免费建站教程十分钟搭建网站?
如何快速搭建高效香港服务器网站?
如何通过网站建站时间优化SEO与用户体验?
Python文件管理规范_工程实践说明【指导】
宁波自助建站系统如何快速打造专业企业网站?
建站之星各版本价格是多少?
官网建站费用明细查询_企业建站套餐价格及收费标准指南
如何用腾讯建站主机快速创建免费网站?
制作网站怎么制作,*游戏网站怎么搭建?
香港服务器部署网站为何提示未备案?
如何选择靠谱的建站公司加盟品牌?
打鱼网站制作软件,波克捕鱼官方号怎么注册?
建站主机类型有哪些?如何正确选型
如何通过商城免费建站系统源码自定义网站主题?
专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?
手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?
建站主机数据库如何配置才能提升网站性能?
济南网站建设制作公司,室内设计网站一般都有哪些功能?
高配服务器限时抢购:企业级配置与回收服务一站式优惠方案
如何通过多用户协作模板快速搭建高效企业网站?
盘锦网站制作公司,盘锦大洼有多少5G网站?
网站制作公司广州有几家,广州尚艺美发学校网站是多少?
济南企业网站制作公司,济南社保单位网上缴费步骤?
建站DNS解析失败?如何正确配置域名服务器?
C++中的Pimpl idiom是什么,有什么好处?(隐藏实现)
如何在建站之星绑定自定义域名?
定制建站价位费用解析与套餐推荐全攻略
中山网站制作网页,中山新生登记系统登记流程?
高端建站如何打造兼具美学与转化的品牌官网?
如何高效生成建站之星成品网站源码?
如何通过虚拟主机快速搭建个人网站?
专业网站设计制作公司,如何制作一个企业网站,建设网站的基本步骤有哪些?
专业网站制作服务公司,有哪些网站可以免费发布招聘信息?
建站之星多图banner生成与模板自定义指南
C++如何编写函数模板?(泛型编程入门)
安云自助建站系统如何快速提升SEO排名?
定制建站策划方案_专业建站与网站建设方案一站式指南
已有域名如何免费搭建网站?
如何通过免费商城建站系统源码自定义网站主题与功能?
如何在香港服务器上快速搭建免备案网站?
交易网站制作流程,我想开通一个网站,注册一个交易网址,需要那些手续?
太平洋网站制作公司,网络用语太平洋是什么意思?
宝塔新建站点报错如何解决?
建站之星安装失败:服务器环境不兼容?
公司网站设计制作厂家,怎么创建自己的一个网站?
网站制作公司,橙子建站是合法的吗?
上海网站制作网站建设公司,建筑电工证网上查询系统入口?
网站制作价目表怎么做,珍爱网婚介费用多少?
如何在Golang中使用replace替换模块_指定本地或远程路径
*请认真填写需求信息,我们会在24小时内与您取得联系。