一、简言

使用数组实现循环队列时,始终会有一个空余的位置预留着,作为一个判决队列已满的条件(当然也可以采用其他方式)。在前面已经用C++介绍了基本的算法,可以去回顾一下https://www.cnblogs.com/XYQ-208910/p/11700048.html。光说不练嘴把式,现在本文使用OC面向对象的思想来实现一下。

 

二、代码

ArrayQueue

//
// ArrayQueue.h
// 运行时
//
// Created by 夏远全 on 2019/10/19.
// #import <Foundation/Foundation.h> NS_ASSUME_NONNULL_BEGIN @interface ArrayQueue : NSObject /**
构造一个循环队列
@param capacity 队列容量
@return 队列
*/
+(instancetype)constrcutArrayQueueWithCapacity:(int)capacity; /**
入队列
@param element 元素
*/
-(void)enQueueWithElement:(id)element; /**
出队列
@return 元素
*/
-(id)deQueueElement; /**
队列是否为空
@return 布尔值
*/
-(BOOL)isEmpty; /**
队列是否已满
@return 布尔值
*/
-(BOOL)isFull; /**
获取元素个数
@return 个数
*/
-(int)eleCount; @end NS_ASSUME_NONNULL_END
//
// ArrayQueue.m
// 运行时
//
// Created by 夏远全 on 2019/10/19.
// #import "ArrayQueue.h" @interface ArrayQueue ()
@property (nonatomic, strong) NSMutableArray *array;
@property (nonatomic, assign) int front;
@property (nonatomic, assign) int rear;
@property (nonatomic, assign) int capacity;
@end @implementation ArrayQueue /**
构造一个循环队列
@param capacity 队列容量
@return 队列
*/
+(instancetype)constrcutArrayQueueWithCapacity:(int)capacity { ///断言一下
assert(capacity>); ArrayQueue *arrayQueue = [[ArrayQueue alloc] init];
arrayQueue.array = [NSMutableArray array]; //初始化容器
arrayQueue.capacity = capacity; //初始化容量
arrayQueue.front = arrayQueue.rear = ; //初始化首尾指针
return arrayQueue;
} /**
入队列
@param element 元素
*/
-(void)enQueueWithElement:(id)element { ///判断队列是否已满
if ([self isFull]) {
NSLog(@"队列已满,元素%@不能被入列, front = %d , rear = %d", element, self.front, self.rear);
return;
} ///插入新元素
self.array[self.rear] = element; ///更新队尾指针
self.rear = (self.rear + ) % self.capacity; NSLog(@"入队列的元素 = %@, front = %d , rear = %d", element, self.front, self.rear);
} /**
出队列
@return 元素
*/
-(id)deQueueElement { ///判断队列是否已空
if ([self isEmpty]) {
NSLog(@"队列已空, front = %d , rear = %d", self.front, self.rear);
return nil;
} ///取出队头的元素
id element = self.array[self.front]; ///更新队头指针
self.front = (self.front + ) % self.capacity; NSLog(@"出队列的元素 = %@, front = %d , rear = %d", element, self.front, self.rear); return element;
} /**
队列是否为空
@return 布尔值
*/
-(BOOL)isEmpty { if (self.front == self.rear) {
return YES;
}
return NO;
} /**
队列是否已满
@return 布尔值
*/
-(BOOL)isFull { if (self.front == (self.rear + ) % self.capacity) {
return YES;
}
return NO;
} /**
获取元素个数
@return 个数
*/
-(int)eleCount { int eleCount = (self.rear - self.front + self.capacity) % self.capacity;
NSLog(@"队列元素个数 = %d", eleCount);
return eleCount;
} @end

三、结果

测试

-(void)test_DataStructure_ArrayQueue {

    /// 构造循环队列
ArrayQueue *arrayQueue = [ArrayQueue constrcutArrayQueueWithCapacity:]; /// enter Queue 入队列
[arrayQueue enQueueWithElement:@()];
[arrayQueue enQueueWithElement:@()];
[arrayQueue enQueueWithElement:@()];
[arrayQueue enQueueWithElement:@()];
[arrayQueue enQueueWithElement:@()]; /// 全部入队后 get eleCount 元素个数
[arrayQueue eleCount]; /// deque Queue 出队列
[arrayQueue deQueueElement];
[arrayQueue deQueueElement];
[arrayQueue deQueueElement];
[arrayQueue deQueueElement];
[arrayQueue deQueueElement]; /// 全部出队后 get eleCount 元素个数
[arrayQueue eleCount]; }

打印

-- ::57.323138+ 运行时[:] 入队列的元素 = , front =  , rear =
-- ::57.323314+ 运行时[:] 入队列的元素 = , front = , rear =
-- ::57.323435+ 运行时[:] 入队列的元素 = , front = , rear =
-- ::57.323544+ 运行时[:] 入队列的元素 = , front = , rear =
-- ::57.323639+ 运行时[:] 队列已满,元素100不能被入列, front = , rear =
-- ::57.323721+ 运行时[:] 队列元素个数 =
-- ::57.323844+ 运行时[:] 出队列的元素 = , front = , rear =
-- ::57.323945+ 运行时[:] 出队列的元素 = , front = , rear =
-- ::57.324033+ 运行时[:] 出队列的元素 = , front = , rear =
-- ::57.324140+ 运行时[:] 出队列的元素 = , front = , rear =
-- ::57.324245+ 运行时[:] 队列已空, front = , rear =
-- ::57.324344+ 运行时[:] 队列元素个数 =

用OC基于数组实现循环队列的更多相关文章

  1. 基于数组的循环队列(C++模板实现)

    循环队列使用数组实现的话,简单.方便.之前实现的队列,当尾端索引到达队列最后的时候,无论前面是否还有空间,都不能再添加数据了.循环队列使得队列的存储单元可以循环利用,它需要一个额外的存储单元来判断队列 ...

  2. 教你如何使用Java手写一个基于数组实现的队列

    一.概述 队列,又称为伫列(queue),是先进先出(FIFO, First-In-First-Out)的线性表.在具体应用中通常用链表或者数组来实现.队列只允许在后端(称为rear)进行插入操作,在 ...

  3. C语言实现使用动态数组实现循环队列

    我在上一篇博客<C语言实现使用静态数组实现循环队列>中实现了使用静态数组来模拟队列的操作. 因为数组的大小已经被指定.无法动态的扩展. 所以在这篇博客中,我换成动态数组来实现. 动态数组能 ...

  4. Java数组实现循环队列的两种方法

    用java实现循环队列的方法: 1.添加一个属性size用来记录眼下的元素个数. 目的是当head=rear的时候.通过size=0还是size=数组长度.来区分队列为空,或者队列已满. 2.数组中仅 ...

  5. 数组模拟循环队列(java实现)

    1.front变量的含义:front就指向队列的第一个元素,也就是说arr[front]就是队列的第一个元素front的初始值=0. 2.rear变量的含义:rear指向队列的最后一个元素的后一个位置 ...

  6. 用OC基于链表实现链队列

    一.简言 在前面已经用C++介绍过链队列的基本算法,可以去回顾一下https://www.cnblogs.com/XYQ-208910/p/11692065.html.少说多做,还是上手撸代码实践一下 ...

  7. 深入理解循环队列----循环数组实现ArrayDeque

    我们知道队列这种数据结构的物理实现方式主要还是两种,一种是链队列(自定义节点类),另一种则是使用数组实现,两者各有优势.此处我们将要介绍的循环队列其实是队列的一种具体实现,由于一般的数组实现的队列结构 ...

  8. 用数组实现队列(顺序队列&循环队列)

    用数组实现队列(顺序队列&循环队列) 顺序队列 ️ 队列(先进先出) 几个问题: 队列方法:入队.出队 队列的存储:即队首队尾两个指针, 扩容:如果队列容量不够了,应该扩容,如果队尾没有位置了 ...

  9. java数据结构---循环队列

    #java学习经验总结------循环队列的实现(数组) package datastructure;/*数组实现循环队列 队列first in first out*/ public class Ci ...

随机推荐

  1. python创建多维字典方法

    python不直接创建多维字典,需要逐层判断不存在创建,存在追加: 例如: 不能直接 dictName['key1']['key2']['key3']['key4']['key5'] = ['123' ...

  2. mysql操作进阶

    # ### part1 单表查询# sql 查询语句的完整语法 ''' select .. from .. where .. group by .. having .. order by .. lim ...

  3. V4 Reduce Transportable Tablespace Downtime using Cross Platform Incremental Backup (Doc ID 2471245.1)

    V4 Reduce Transportable Tablespace Downtime using Cross Platform Incremental Backup (Doc ID 2471245. ...

  4. 如何在Mac上使用Siri

    在您的iPhone上,要求Siri执行命令很简单.但是,如果在计算机上工作时附近没有iPhone,会发生什么情况?您也可以在Mac上使用Siri.快速简便,使其成为iMac或MacBook的完美伴侣. ...

  5. 2019-2020-1 20199305《Linux内核原理与分析》第十一周作业

    ShellShock 攻击实验 (一)何为ShellShock? 2014年9月24日,Bash中发现了一个严重漏洞shellshock,该漏洞可用于许多系统,并且既可以远程也可以在本地触发,这项漏洞 ...

  6. SpringData JPA实现增删改

    一.创建实体类并自动生成数据库表 二.dao层继承JpaRepository 三.controller中增加操作 四.controller中删除操作 五.controller中修改操作

  7. rmi与rpc的区别

    这里简单说一下RMI和RPC的区别. 什么是RMI RMI(Remote Method Invocation,远程方法调用),能够让在客户端Java虚拟机上的对象像调用本地对象一样调用服务端Java虚 ...

  8. ASP.NET Core 2.2 WebApi 系列【八】统一返回格式(返回值、模型验证、异常)

    现阶段,基本上都是前后端分离项目,这样一来,就需要前后端配合,没有统一返回格式,那么对接起来会很麻烦,浪费时间.我们需要把所有接口及异常错误信息都返回一定的Json格式,有利于前端处理,从而提高了工作 ...

  9. GIT命令行统计代码提交行数

    项目中遇到写报告的时候要反馈某个人或者某个功能的代码量,又没有集成CI这些插件,可以简单的用GIT命令统计下代码提交量: --统计某个人的提交代码 git log --author="old ...

  10. QT总结

    作为一个QT(C++/linux/windows)开发工程师,把自己在工作中遇到的一些QT问题持续总结给大家,一起分享: 一.隐藏鼠标:QApplication::setOverrideCursor( ...