数组实现循环队列

1、分析

循环队列最主要的特点为当前面的空间被pop后,后面的数据可以插入到前面空余的数据中去;

所以最难的部分为判断什么时候为空什么时候为满:

a、空满问题

我们先来分析当数据满时,head和tail相等(tail认为是指向队尾的下一个空间,因为书写起来比较容易)。

那么什么时候为满呢?

b、空满问题解决

显然当tail和head相等时为满,那么这就会导致逻辑混乱。解决方法有以下两种:
法一:增加一个size变量用来记录队列大小,0为空,满为等于申请的空间值;

法二:额外开一个空间;

所以当head==tail+1%k时空间为满,head==tail时为空(k为给定的k+1) 

本人采用第二种方法(为了保证tail和head的有效性时我们会给其%k)

c、tail为0时的插入数据

所以当tail为0时插到k的位置。

或者直接用这个公式:(这个时力扣官方给出的结果)

obj->elements[(obj->rear - 1 + obj->capacity) % obj->capacity]

2、实现

typedef struct {int* a;int head;int tail;int k;} MyCircularQueue;MyCircularQueue* myCircularQueueCreate(int k) {MyCircularQueue*mq =(MyCircularQueue*)malloc(sizeof(MyCircularQueue));mq->a=(int*)malloc((k+1)*sizeof(int));mq->head=mq->tail=0;mq->k=k+1;return mq;
}bool myCircularQueueEnQueue(MyCircularQueue* obj, int value) {if((obj->tail+1)%obj->k==obj->head){return false;}obj->a[obj->tail]=value;obj->tail=(obj->tail+1)%obj->k;return true;
}bool myCircularQueueDeQueue(MyCircularQueue* obj) {if(obj->tail==obj->head){return false;}obj->head=(obj->head+1)%(obj->k);return true;
}int myCircularQueueFront(MyCircularQueue* obj) 
{if(obj->tail==obj->head){return -1;} return obj->a[obj->head];
}int myCircularQueueRear(MyCircularQueue* obj) {if(obj->head==obj->tail){return -1;}return obj->a[(obj->tail-1+obj->k)%obj->k];
}bool myCircularQueueIsEmpty(MyCircularQueue* obj) {return (obj->head)==(obj->tail);
}bool myCircularQueueIsFull(MyCircularQueue* obj) {return (obj->head)==(obj->tail+1)%(obj->k);
}void myCircularQueueFree(MyCircularQueue* obj) {free(obj->a);free(obj);
}/*** Your MyCircularQueue struct will be instantiated and called as such:* MyCircularQueue* obj = myCircularQueueCreate(k);* bool param_1 = myCircularQueueEnQueue(obj, value);* bool param_2 = myCircularQueueDeQueue(obj);* int param_3 = myCircularQueueFront(obj);* int param_4 = myCircularQueueRear(obj);* bool param_5 = myCircularQueueIsEmpty(obj);* bool param_6 = myCircularQueueIsFull(obj);* myCircularQueueFree(obj);
*/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/836216.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Android 按键消息流程源码分析

在Android系统中,键盘按键事件是由SystemServer服务来管理的;然后在以消息的形式分发给应用程序处理。产生键盘按键事件则是有Linux kernel的相关驱动来实现。键盘消息有别于其他类型的消息;需要从Linux kernel drivers产生由上层APP来处理。…

在做题中学习(57):寻找数组的中心下标

724. 寻找数组的中心下标 - 力扣(LeetCode) 解法:前缀和后缀和 思路:要看一个数是不是中心下标,就看他前面数的和 与 后面数的和 相不相等。 1.i前面数的和,是[0,i-1] 的前缀和,i后面数的和&am…

综合性练习(验证码案例)

目录 一、需求 二、准备工作 三、约定前后端交互接口 1、需求分析 2、接口定义 四、Hutool工具介绍 1、引入依赖 2、测试使用Hutool生成验证码 五、实现服务器端代码 代码解读: 六、调整前端页面代码 七、运行测试 随着安全性的要求越来越高&#xff0c…

软件体系结构论述

一、软件危机 1.软件成本日益增长 2.开发进度难以控制 3.软件质量差 4.软件维护困难 软件危机的原因 1.用户需求不明确 2.缺少正确的理论 3.软件规模大 4.软件复杂度高 如何克服软件危机 用工程,科学,数学的原则和方法…

素描石膏像常见问题及解决方法

在学习和练习素描绘画石膏像时,可能会遇到一些常见问题。以下是一些可能出现的问题以及相应的解决方法: 难以把握光影和阴影的分布: 解决方法:观察石膏像的光源方向,注意光线的照射和阴影的形成。练习观察真实的光影效…

Linux 第二十八章

🐶博主主页:ᰔᩚ. 一怀明月ꦿ ❤️‍🔥专栏系列:线性代数,C初学者入门训练,题解C,C的使用文章,「初学」C,linux 🔥座右铭:“不要等到什么都没有了…

欢乐钓鱼大师攻略,怎么获取道具?

在《欢乐钓鱼大师》的游戏世界中,道具是提升钓鱼体验、解锁新功能以及完成挑战的关键。通过多种方式获取道具,能够帮助玩家更好地探索游戏世界、挑战自我,以及与其他玩家展开竞争。以下是关于如何获取道具的详细攻略,让你能够在游…

proteus示波器不弹出来

运行后示波器没有弹出来 点击调试(Debug)在点击Digital Oscilloscope 完成

Flutter-加载中动画

效果 考察内容 AnimationControllerTweenAnimatedBuilderTransformMatrix4 实现 ///源码&#xff1a;https://github.com/yixiaolunhui/flutter_xy class LoadingView extends StatefulWidget {const LoadingView({Key? key}) : super(key: key);overrideState<LoadingV…

web前端之excel转pdf、小黄人发送请求、base64、jspdf、xlsx

MENU 前言方案一方案二结束语 前言 在前端将Excel转换为PDF有多种方案&#xff0c;本文介绍两种简单方案。 方案一 使用jspdf库&#xff0c;先将Excel文件转成Base64格式&#xff0c;然后再使用jspdf库将其转换为PDF格式&#xff0c;最后使用saveAs函数下载PDF文件。 步骤一: 安…

牛客前端面试2

fetch请求方式 是什么 fetch是一种HTTP数据请求的方式&#xff0c; 用于发起网络请求 是XMLHttpRequest的一种替代方案。 Fetch函数就是原生js&#xff0c;没有使用XMLHttpRequest对象。 fetch()方法返回一个Promise解析Response来自Request显示状态&#xff08;成功与否&am…

探索循环购模式:消费返利与积分机制的创新融合

大家好&#xff0c;我是吴军&#xff0c;今天非常荣幸能与大家分享一种别具一格的商业模式——循环购模式。这种商业模式在近年来逐渐崭露头角&#xff0c;受到了广大消费者的热烈追捧。或许您之前听说过消费满额即送现金的活动&#xff0c;但循环购模式不仅仅局限于此&#xf…

基于机器学习的网络流量识别分类(完整资源收米)NetFlow-Sentry

项目介绍 这是一个名为NetFlow-Sentry的项目&#xff0c;项目实现了对网络流量的实时检测&#xff0c;特征抓取&#xff0c;内置了基于Pytorch的深度学习模型来进行流量分类。该项目除可以进行实时特征提取&#xff0c;还提供了网络流量数据的输入口&#xff0c;可以直接识别分…

【Arduino】ESP32/ESP8266 JSON格式解析

目录 1、JSON 2、JSON语法格式 基本概念&#xff1a; 语法规则&#xff1a; 数据类型&#xff1a; 示例&#xff1a; 3、JSON解析 单一对象JSON解析&#xff08;无嵌套&#xff09; JSON数组解析 使用ArduinoJson官网在线工具解析JSON信息 ESP8266闪存存储的JSON解析…

Java语言的魅力与未来展望

Java&#xff0c;作为当今最流行的编程语言之一&#xff0c;凭借其独特的优势在全球编程界中占据着重要地位。自1995年诞生以来&#xff0c;Java以其跨平台、面向对象、安全稳定等特性&#xff0c;赢得了开发者的广泛青睐。 Java的跨平台特性是其最大的亮点之一。通过Java虚拟…

MySQL性能优化(提升数据库性能的措施)

万物皆有裂痕&#xff0c;那是光照进来的地方。大家好&#xff0c;今天给大家分享一下关于MySQL性能优化&#xff0c;在处理大型数据集和高负载情况下&#xff0c;MySQL数据库的性能优化是至关重要的。通过合理的调优策略&#xff0c;可以有效提高数据库的响应速度和稳定性。本…

正点原子[第二期]Linux之ARM(MX6U)裸机篇学习笔记-13-按键实验

前言&#xff1a; 本文是根据哔哩哔哩网站上“正点原子[第二期]Linux之ARM&#xff08;MX6U&#xff09;裸机篇”视频的学习笔记&#xff0c;在这里会记录下正点原子 I.MX6ULL 开发板的配套视频教程所作的实验和学习笔记内容。本文大量引用了正点原子教学视频和链接中的内容。…

xhci 寄存器学习

xhci 寄存器介绍 查看linux 代码&#xff1a; 1733 /* There is one xhci_hcd structure per controller */ 1734 struct xhci_hcd { 1735 struct usb_hcd *main_hcd; 1736 struct usb_hcd *shared_hcd; 1737 /* glue to PCI and HCD framework */ 1738 stru…

哈希表第5/9题--两数之和

题目描述&#xff1a; 给定一个整数数组 nums 和一个整数目标值 target&#xff0c;请你在该数组中找出 和为目标值 target 的那 两个 整数&#xff0c;并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是&#xff0c;数组中同一个元素在答案里不能重复出现。…

实操专区-第11周-课堂练习专区-图的标记线和标记点

下载安装ECharts&#xff0c;完成如下样式图形。 代码和截图上传 完成 3.1.3.5 图的标记线和标记点 中的任务点 在一些折线图或柱状图当中&#xff0c;可以经常看到图中对最高值和最低值进行了标记。 在ECharts中&#xff0c;标记点&#xff08;markPoint&#xff09;常用于表示…