TypeScript算法与数据结构-队列和循环队列
1. 队列(Queue)
队列也是一种线性的数据结构, 队列是一种先进先出的数据结构。类似于生活中的排队买东西,先进入队列的人可以先购买到东西。这次的队列具体实现依然会采用之前自己封装好的数组,具体的优势依然是我们可以清晰的算出每次操作的时间复杂度。对于基本的队列而言,主要包含两个基本的操作入队(enqueue)和出队(dequeue)。
对于队列而言,入队发生在尾部,出队发生在首部,队列是一种先进先出的数据结构First in First out。
我们依然会给队列定义一个接口,然队列类实现这个接口
interface Queue<E> {
getSize(): number; // 获取队列中元素的个数
isEmpty(): boolean; // 判断队列中的元素是否为空
enqueue(e: E): void; // 入队一个元素
dequeue(): E; // 出队一个元素
getFront(): E; // 获取当前队首的元素
}
1.1 构造函数
这里我们用到了之前封装好的数组
class ArrayQueue<E> implements Queue<E> {
private array: MyArray<E>;
constructor(capacity = 10) {
this.array = new MyArray<E>(capacity);
}
}
1.2 入队
入队我们只需要将元素添加到array的尾部,这里的时间复杂度为O(1)
enqueue(e: E): void {
this.array.addLast(e);
}

1.3 出队
出队的话我们需要将元素从array的头部移除,这里的时间复杂度为O(n)。这里为什么需要O(n)的时间复杂度,因为一旦我们要将第一个元素移除,那我们必须遍历整个array,将从位置1开始的每个元素向前移动一个位置。
dequeue(): E {
return this.array.removeFirst();
}

2.循环队列
循环队列是对队列的一种优化,入队和出队时,在不触发扩容和缩容操作的情况下,均能实现O(1)的时间复杂度。循环队列的原理是利用两个指针,一个指向队列的头部,一个指向队列的尾部。对于循环队列而言我们依然会实现上面的接口。
这里的构造函数会和之前的构造函数有所不同,主要是添加了两个执行队列头元素和队列尾元素的指针,初始状态下,循环队列的头指针和尾指针都
class LoopQueue<E> implements Queue<E> {
private data: Array<E>;
private front: number = 0;
private tail: number = 0;
private size: number = 0;
constructor(capacity = 10) {
this.data = new Array<E>(capacity + 1); // 这里需要在用户传入初始容量的基础上加1
}
}
2.1 入队
循环队列入队的操作非常简单,将tail节点所指向的节点赋值为所需要添加的节点e,然后维护一下tail指针所指向的位置。这里有一点需要注意的是,当队尾没有空元素时,队列尾指针会循环至队列的头部,然后从头开始。这也就是为什么称之为循环队列。循环队列的入队操作的时间复杂度为O(1)。
enqueue(e: E) {
// 如果循环队列已满,那此时需要扩容
if ((this.tail + 1) % this.data.length === this.front) {
this.resize(this.getCapacity() * 2);
}
this.data[this.tail] = e;
this.tail = (this.tail + 1) % this.data.length;
this.size++;
}

2.2 出队
出队的操作和入队相似,将当前front位置的元素置为undefined,然后维护一下front指针的位置。同样的,在不触发缩容操作的情况下,出队操作能保证O(1)的时间复杂度
dequeue(): E {
if (this.isEmpty()) {
throw new Error('Cannot dequeue from an empty queue.');
}
let ret: E = this.data[this.front];
this.data[this.front] = undefined;
this.front = (this.front + 1) % this.data.length;
this.size--;
if (this.size === this.getCapacity() / 4 && this.getCapacity() / 2 !== 0) {
this.resize(this.getCapacity() / 2);
}
return ret;
}

2.3 循环队列的优势
循环队列的优势在于
- 循环队列最大程度的利用的数组的空间,节省内存
- 循环队列实现了入队和出队的操作都是O(1)的时间复杂度
TypeScript算法与数据结构-队列和循环队列的更多相关文章
- javascript实现数据结构与算法系列:队列 -- 链队列和循环队列实现及示例
1 队列的基本概念 队列(Queue):也是运算受限的线性表.是一种先进先出(First In First Out ,简称FIFO)的线性表.只允许在表的一端进行插入,而在另一端进行删除. 队首(fr ...
- [从今天开始修炼数据结构]队列、循环队列、PriorityQueue的原理及实现
[从今天开始修炼数据结构]基本概念 [从今天开始修炼数据结构]线性表及其实现以及实现有Itertor的ArrayList和LinkedList [从今天开始修炼数据结构]栈.斐波那契数列.逆波兰四则运 ...
- C ~ 链式队列与循环队列
此处的链式与循环队列可以应用于BFS和树的层序遍历.下面是对其结构和基本操作的程序描述. 1.循环队列 解决循环队列的队空和队满的方法: [1].增加一个参数count,用来记录数组中当前 ...
- 数据结构Java实现07----队列:顺序队列&顺序循环队列、链式队列、顺序优先队列
一.队列的概念: 队列(简称作队,Queue)也是一种特殊的线性表,队列的数据元素以及数据元素间的逻辑关系和线性表完全相同,其差别是线性表允许在任意位置插入和删除,而队列只允许在其一端进行插入操作在其 ...
- 数据结构----队列:顺序队列&顺序循环队列、链式队列、顺序优先队列
一.队列的概念: 队列(简称作队,Queue)也是一种特殊的线性表,队列的数据元素以及数据元素间的逻辑关系和线性表完全相同,其差别是线性表允许在任意位置插入和删除,而队列只允许在其一端进行插入操作在其 ...
- java数据结构——队列、循环队列(Queue)
每天进步一点点,坚持就是成功. 1.队列 /** * 人无完人,如有bug,还请斧正 * 继续学习Java数据结构————队列(列队) * 队列和栈一样,都是使用数组,但是队列多了一个队头,队头访问数 ...
- 算法与数据结构(二) 栈与队列的线性和链式表示(Swift版)
数据结构中的栈与队列还是经常使用的,栈与队列其实就是线性表的一种应用.因为线性队列分为顺序存储和链式存储,所以栈可以分为链栈和顺序栈,队列也可分为顺序队列和链队列.本篇博客其实就是<数据结构之线 ...
- C# 数据结构基础-实现循环队列
队列 队列的概念是先进先出,这个应该不用多说了.看下面那个从网上找的现成图片. 循环队列 循环队列在逻辑上将队列中的数据摆成环形,如下图: 下面直接上代码. 队列 队列的概念是先进先出 ...
- 队列(循环队列)----C语言
线性结构:有且只有一个根节点,且每个节点最多有一个直接前驱和一个直接后继的非空数据结构 非线性结构:不满足线性结构的数据结构 队列 队列一般分为两类:链式队列和顺序队列 链式队列---链式队列即用链表 ...
随机推荐
- WPF 资源(StaticResource 静态资源、DynamicResource 动态资源、添加二进制资源、绑定资源树)
原文:WPF 资源(StaticResource 静态资源.DynamicResource 动态资源.添加二进制资源.绑定资源树) 一.WPF对象级(Window对象)资源的定义与查找 实例一: St ...
- comtextMenu 如何正确的响应MouseLeave事件
今天给菜单加上这个事件,发现弹出菜单后 鼠标怎么动都不会触发 mouseLeave事件 解决方法是 在菜单loaded事件中,利用visualTreeHelper 访问他内部的border控件,把这个 ...
- Windows 10开发基础——网络编程
主要内容: HttpClient类 Socket通信 WCF通信 HttpClient类 在UWP中可以用来进行网络通信的HttpClient类有两个,System.Net.Http.Htt ...
- Win8Metro(C#)数字图像处理--2.3图像反色
原文:Win8Metro(C#)数字图像处理--2.3图像反色 [函数名称] 图像反色函数ContraryProcess(WriteableBitmap src) [算法说明] 反色公式如下: ...
- C#破解access数据库密码方法
原文:C#破解access数据库密码方法 using System; using System.Collections.Generic; using System.IO; using System.L ...
- 判断jQuery选择器结果为空 - CSDN博客
原文:判断jQuery选择器结果为空 - CSDN博客 jQuery选择器获取到的是一个对象,所以无论页面上存在或者不存在元素,这个对象都不为空.因此,如果要使用jQuery检查元素再给某个页面上是否 ...
- Mongodb Compile C++ Driver
之前发现直接编译mongo源码中的驱动,静态库的驱动会很大,在链接使用的时候会报很多链接错误. 转而直接编译单独提供驱动源码,同样vc2008的版本也要做我的另一篇博文中修改,在这不多说,具体参见: ...
- qt的demo中,经常可以看到emum
最近开始看QT的文档,发现了很多好东西,至少对于我来说 收获很多~~~ 当然很多东西自己还不能理解的很透彻,也是和朋友讨论以后才渐渐清晰的,可能对于QT中一些经典的用意我还是存在会有些认识上的偏差,欢 ...
- BI-学习之 商业智能项目工具安装
首先咱们先需要下载一个工具,Microsoft SQL Server Data Tools - Business Intelligence for Visual Studio 2012并安装: 我目前 ...
- Windows窗体原理及控件WM_DRAWITEM和子类化重绘演示文件
http://download.csdn.net/detail/wenzhou1219/6783959