首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

简单快速记忆js数组栈和队列函数

js中,对数组的操作是比较常见的,有时候,我们需要模拟栈和队列的特性才能实现需求,今天来给大家用通俗易懂、简洁明了的几行文字,来告诉大家栈和队列的几个函数,如何快速记住。...队列(queue)是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表。...js中没有专门栈和队列类型,其实都是用数组模拟的 栈:一端封闭,只能从另一端进出的数组 FILO(first in last out) 先进的后出 栈进出分为两种: 结尾出入栈:...何时使用栈: 保证始终使用数组中最新的元素时 eg:ECS 执行环境栈 浏览器永远访问最新的网址,外面是历史记录栈 队列: 只能从一端进入,从另一端出 FIFO(...何时使用队列: 希望按照先来后到的顺序使用数据时 函数速记: pop()与shift()都是删除 pop()删除数组中的最后一个元素,并返回该元素 shift()删除数组中的第一个元素,并返回该元素 push

57520

数组模拟队列

队列是一个有序列表,可以用数组或链表来实现,队列遵循先进先出的原则,即先存入的队列的数据要先取出,比如银行的排队叫号系统。...数组模拟队列 如下示意图,MaxSize代表队列能存储的最大容量 front和rear分别代表队列的前后端下标,它们初始化都为1; 当向队列中添加数据时,front不会发生改变,rear会不断递增。...数组模拟环形队列 上述代码已经完成了一个最基本的队列,但是存在问题如下 目前数组只能使用一次,达不到复用效果,数组中被取出的空间不能被利用 解决办法 将这个数组使用算法改进成环形数组,就可以达到复用的效果...为什么变成0因为到3的时候已经是数组的尽头了,只能往数组前面看看还有没有可以存数据的地方,这里就是0 这个时候在还没有取出数据的情况下,我们在向这个队列添加数据 首先会进行判断 (0+1) % 4 =1...:(rear+maxSize-front) % maxSize 数组模拟环形队列代码实现 class CircleArray{ private int maxSize; //数组最大容量

30620
您找到你想要的搜索结果了吗?
是的
没有找到

数组队列

一.队列的概念 (1)队列也是一种线性结构 (2)相比数组队列对应的操作是数组的子集 (3)只允许在一端插入数据操作,在另一端进行删除数据操作,进行插入操作的一端称为队尾(入队列),进行删除操作的一端称为队头...(出队列) (4)队列是一种先进先出的数据结构(FIFO)  此处我们先来学习一下顺序队列 ,顺序队列 就是用数组实现:比如有一个n个元素的队列数组下标0的一端是队头,入队操作就是通过数组下标一个个顺序追加...对于队列,我们关注的相关实现如下: ? 二、代码实现 对于该节的相关代码,我们新建一个package(Queue),同时为了理解方便,此时把动态数组相关代码拷贝到该包中。...三、数组队列的复杂度分析 ?...对于出队的时间复杂度为O(n)的解释:  由于实现数组队列的底层是动态数组,入队操作就是通过数组下标一个个顺序追加,不需要移动元素,但是如果删除队头元素(removeFirst()方法),后面的元素就要往前移动

49360

循环队列出队-数组循环队列

我们知道队列这种数据结构的物理实现方式主要还是两种,一种是链队列(自定义节点类),另一种则是使用数组实现,两者各有优势。...此处我们将要介绍的循环队列其实是队列的一种具体实现,由于一般的数组实现的队列结构在频繁出队的情况下,会产生假溢出现象循环队列出队,导致数组使用效率降低,所以引入循环队列这种结构。...本文将从以下两个大角度介绍循环队列这种数据结构:   一、循环队列   为了深刻体会到循环队列这个结构优于非循环队列的地方,我们将首先介绍数组实现的非循环队列结构。...队列这种数据结构,无论你是用链表实现,还是用数组实现,它都是要有两个指针分别指向队头和队尾。在我们数组的实现方式中,用两个int型变量用于记录队头和队尾的索引。   ...按照我们的想法,一旦tail到达数组边界,那么可以通过与数组长度取模返回初始位置,这种情况下判断队满的条件为tail=head   此时tail的值为8,取模数组长度8得到0,发现head=tail,此时认为队列满员

1K10

邂逅数组队列

数据结构与算法一 线性结构与非线性结构 稀疏数组及五子棋问题 二维数组与稀疏数组的转化 遍历二维数组的两种方式 队列和银行排队问题 银行排队问题 队列队列模拟 队列 循环队列 学习完部分大数据知识之后...队列队列模拟 下面我们来学习线性结构的一种数据结构: 队列 队列是一个有序表, 编程上可以通过数组和链表来实现 遵循先入先出原则....++) 队列为空时, front=rear, 队列满时, rear=MaxSize-1 (MaxSize为数组最大容量) ?...利用数组模拟队列 队列本身是有序列表,若使用数组的结构来存储队列的数据,则队列数组的声明如下图, 其中 maxSize 是该队列的最大容量。...队列 数组模拟队列代码 在创建队列这个实体类时, 需要一个构造函数, 构造函数无返回值.

51510

稀疏数组队列

# 稀疏数组队列 稀疏 sparsearray 数组 先看一个实际的需求 稀疏数组基本介绍 应用案例 代码实现 课后作业 队列 队列的一个使用场景 队列介绍 数组模拟队列思路 代码演示 数组模拟环形队列...分析问题 因为该二维数组的很多值是默认值0,因此记录了很多没有意义的数据.->稀疏数组。 # 稀疏数组基本介绍 当一个数组中大部分元素为0,或者为同一个值的数组时,可以使用稀疏数组来保存该数组。...# 队列的一个使用场景 银行排队的案例: # 队列介绍 队列是一个有序列表,可以用数组或是链表来实现。...后存入的要后取出 示意图:(使用数组模拟队列示意图) # 数组模拟队列思路 队列本身是有序列表,若使用数组的结构来存储队列的数据,则队列数组的声明如下图,其中 maxSize是该队列的最大容量。...Process finished with exit code 0 出现问题,数据虽然取出了,但是队列不能再进行添加数据,不能达到复用的效果 # 数组模拟环形队列 对前面的数组模拟队列的优化,充分利用数组

36120

数组模拟队列思路

队列 队列介绍 队列是一个有序列表,可以用链表或数组实现。 遵循先入先出的原则:即先存入队列的数据要先取出,后存入队列的数据要后取出。...实现思路 插入元素: 每次插入数据前需要判断队列是否已经满了,满了则无法插入。 如果队列未满,可以在头部将元素进行插入。 删除元素: 每次删除元素前需要判断是否还有元素。...rear = -1; //队列当前结尾位置 } /** * 判断当前队列是否满了 */ public boolean...//当前队列并没有元素,返回-1 return 0; } //当前队列有元素,需要将结尾位置减去1,并且将数组元素全部往前面挪动一位,然后函数返回抽出来的元素...arr[i-1]=arr[i]; } rear--; return returnNum; } /** * 遍历当前数组的所有元素并且将其输出

21530

数组实现循环队列(增设队列大小size)

一、前言利用数组实现循环队列,重点要解决的问题有三个:1.如何实现循环?由于数组大小k是确定的,要实现队列循环就需要让数组下标循环,利用两个下标front、back分别指向首元素和尾元素的下一个位置。...我们发现,当队列满时,由于back指向队尾元素的下一个,因此队列满时,front = back ,与队列空时相矛盾。如何解决呢?...两种解决方法:一是:循环队列结构中新增队列大小 size ,当size=0且front = back时,队列为空;当size≠0且front = back时,队列为满。...本文仅讲解方法一,方法二详解:数组实现循环队列(新增一个空间)-CSDN博客二、循环队列的结构定义循环队列的结构中包含数组、头指针、尾指针、队列容量、队列大小(队列大小用于区分队列空与满的情况)//方法一...由此需要判断尾指针是否指向0位置,如果指向0位置则不能back-1,否则越界,需要返回数组的最后一个位置元素,即k-1的位置;如果不指向0位置,则返回back-1位置的元素即可。

13310

使用数组模拟队列、循环队列和栈

但是如果在考试中或者笔试面试中,为了要使用栈和队列,而去写一个完整的数据结构是比较大费周章,况且在时间上也不一定允许,因此,使用数组来模拟栈和队列的实现是一种明智的选择,原因有两个: 一、使用数组模拟队列和栈可以简化编程的复杂度...二、使用数组模拟的栈和队列在效率上比标准库的容器类高很多,可以使得程序执行的速度更快。...1.数组模拟栈的实现 数组模拟栈的的实现,在栈顶指针的处理上,一般有两种处理方式top=-1,和top=0,也就意味着在这两种情况下对栈的操作是不相同的。...isEmpty()) return -1; return q[++ f]; } bool isEmpty() {return f==r;} bool isFull() {return r==N-1;} 3.数组模拟循环队列的实现...循环队列虽然能够解决上述的问题,但是在判断队列空和队列满的两种状态上需要处理的比较好,非则也会出现不知队列是空还是满。目前比较常用的方式是:牺牲一个位置存储空间来判别队列的两种状态。

71020

js数组浅拷贝_js数组深度复制

数组的浅拷贝, 可用concat、slice返回一个新数组的特性来实现拷贝 var arr = ['old', 1, true, null, undefined]; var new_arr = arr.concat...source.a.b = 10; console.log(source); // { a: { b: 10 } }; console.log(target); // { a: { b: 10 } }; 但是如果数组嵌套了对象或者数组的话用...== 'object') return; // 根据obj的类型判断是新建一个数组还是一个对象 var newObj = Array.isArray(obj) ?...,就会拷贝一份,互不影响,而如果是对象或者数组,就会只拷贝对象和数组的引用,这样我们无论在新旧数组进行了修改,两者都会发生变化。...数组的深拷贝 方法一:JSON.stringify()不仅可拷贝数组还能拷贝对象(但不能拷贝函数,也不能解决循环引用问题) var arr = ['old', 1, true, ['old1', 'old2

13.1K50

html js 数组添加,js数组添加数据

本文介绍js数组添加数据的三种方法:1、结尾添加push()方法;2、头部添加unshift() 方法;3、向/从数组指定位置添加/删除项目,然后返回被删除的项目splice() 方法。...要添加到数组的第一个元素。 b:可选。要添加到数组的第二个元素。 c:可选。可添加多个元素。 3、返回值 把指定的值添加到数组后的新长度。...向数组添加的第一个元素。 b:可选。向数组添加的第二个元素。 c:可选。可添加若干个元素。 3、返回值 arrayObject 的新长度。...整数,规定添加/删除项目的位置,使用负数可从数组结尾处规定位置。 b:必需。要删除的项目数量。如果设置为 0,则不会删除项目。 item1,…..,itemX:可选。向数组添加的新项目。...tony alert(arr.splice(1,0,’tony’)) //返回值为空 alert(arr) // smile,tony,2,3,marie 以上就是js数组添加数据的四种方法,大家可以根据在不同的位置添加数据选择不同的方法哦

26K10

JS异步之宏队列与微队列

原理图 JS中用来存储待执行回调函数的队列包含2个不同特定的列队 宏列队:用来保存待执行的宏任务(回调),比如:定时器回调/DOM事件回调/ajax回调 微列队:用来保存待执行的微任务(回调...),比如:promise的回调/MutationObserver的回调 JS执行时会区别这2个队列 JS引擎首先必须先执行所有的初始化同步任务代码 每次准备取出第一个宏任务执行前,都要将所有的微任务一个一个取出来执行...当该宏任务执行完成,会检查其中的微任务队列,如果为空则直接执行下一个宏任务,如果不为空,则依次执行微任务,执行完成才去执行下一个宏任务。...onResolved2() 2 timeout callback1() Promise onResolved3() 3 timeout callback2() 可能存在的问题 如果一个Microtask队列太长

83430

队列 | 如何使用数组和链表来实现“队列

实现一个队列的数据结构,使其具有入队列、出队列、查看队列首尾元素、查看队列大小等功能。与实现栈的方法类似,队列的实现也有两种方法,分别为采用数组来实现和采用链表来实现。下面分别详细介绍这两种方法。...数组实现 分析 下图给出了一种最简单的实现方式,用front来记录队列首元素的位置,用rear来记录队列尾元素往后一个位置。 ?...入队列的时候只需要将待入队列的元素放到数组下标为rear的位置,同时执行rear++,出队列的时候只需要执行front++即可。 ?...OK,自此,使用数组实现队列已经搞定。 问题 出队列数组前半部分的空间不能够充分地利用,解决这个问题的方法为把数组看成一个环状的空间(循环队列)。...当数组最后一个位置被占用后,可以从数组首位置开始循环利用。 链表实现 分析 采用链表实现队列的方法与实现栈的方法类似,分别用两个指针指向队列的首元素与尾元素,如下图所示。

1.5K20
领券