【队列】循环队列(Circular Queue)详解

【队列】循环队列(Circular Queue)详解

文章目录

一、循环队列简介

在实际开发中,队列是一种常用的数据结构,而循环队列(Circular Queue)则一般是一种基于数组实现的队列(也可使用循环链表)。与传统的 FIFO 队列相比,循环队列通过将数组首尾相连形成一个 “环”,能够更高效地利用内存空间。

循环队列的主要思想是:当队尾指针到达数组末端时,如果数组前面还有空余空间,就可以从数组头部重新利用这些空间进行入队操作。也就是说,数组的末端和头部通过逻辑上的连接,形成一个环状结构,从而避免了顺序队列中由于出队操作而导致的空间浪费问题。

如下图就是一个典型的循环队列,其中的 front 表示头指针,指向队头。rear 则表示尾指针,指向队尾元素的下一个位置。

请添加图片描述

二、循环队列的判空和判满

在循环队列中,frontrear 都是可以循环移动的,当队空时,front == rear 成立;当队满时,front == rear 也成立。因此显然不能只凭 front == rear 来判断队空还是队满。

为了解决这个问题,在循环队列中约定:少用一个元素空间,当队尾标识的 rear在队头标识front 的上一个位置时,队列为满。此时,判断队空和队满的条件分别如下:

队空时:front == rear

队满时:(rear + 1) % MAXSIZE == front

其中,MAXSIZE 是队列容量的大小

两种情况下队列中指针的状态如下图所示:

请添加图片描述

既然少一个元素空间,这就意味着,如果要存储的数据个数最大为 k,那么你需要开辟的循环队列的大小应为 k+1

三、循环队列的实现

我们来以具体的一道题目来实现循环队列的各种操作

leetcode 622. 设计循环队列

typedefstruct{int* a;int front;// 头“指针”指向队头数据int tail;// 尾“指针”指向队尾的下一个位置int k;// 一会儿开辟的队列大小为 k+1} MyCircularQueue; bool myCircularQueueIsEmpty(MyCircularQueue* obj); bool myCircularQueueIsFull(MyCircularQueue* obj);// 前面先实现的函数要用到这两个接口,所以事先声明一下// 循环队列的初始化 MyCircularQueue*myCircularQueueCreate(int k){ MyCircularQueue* cq =(MyCircularQueue*)malloc(sizeof(MyCircularQueue)); cq->a =(int*)malloc(sizeof(int)*(k+1)); cq->front =0;// 初始化数据 cq->tail =0; cq->k = k;return cq;}// 入队 bool myCircularQueueEnQueue(MyCircularQueue* obj,int value){if(myCircularQueueIsFull(obj))return false;// 满了就不能再入了 obj->a[obj->tail]= value;// 将数据入进来++obj->tail;// 更新tail obj->tail %=(obj->k+1);// tail 自增了之后可能超出循环队列的大小范围所以要取模// 模的是循环队列的大小 k+1return true;}// 出队 bool myCircularQueueDeQueue(MyCircularQueue* obj){if(myCircularQueueIsEmpty(obj))return false;// 为空就不能再删 obj->front =(obj->front+1)%(obj->k+1);// 和前面是一样的原理,注意同样是加一再取模return true;}// 获取队头元素intmyCircularQueueFront(MyCircularQueue* obj){if(myCircularQueueIsEmpty(obj))return-1;return obj->a[obj->front];}// 获取队尾元素intmyCircularQueueRear(MyCircularQueue* obj){if(myCircularQueueIsEmpty(obj))return-1;if(obj->tail ==0)return obj->a[obj->k];// 跨越了一个循环的情况elsereturn obj->a[obj->tail-1];}// 判空 bool myCircularQueueIsEmpty(MyCircularQueue* obj){return obj->front == obj->tail;}// 判满 bool myCircularQueueIsFull(MyCircularQueue* obj){return(obj->tail+1)%(obj->k+1)== obj->front;// tail的后一个是front说明满了,但是有可能tail+1跨过了一个循环。所以要取模}// 释放voidmyCircularQueueFree(MyCircularQueue* obj){free(obj->a);// 注意这里要先释放结构体内的数组!!!不然会可能内存泄漏free(obj);}

Read more

Cameralink 图像输出和采集时序,针对FPGA开发

Cameralink 图像输出和采集时序,针对FPGA开发

Cameralink使用接口芯片进行开发的时候,例如国产芯片GM8283、GM8284,GM8284等等。都可以支持宽温85Mhz以上。老外的芯片:例如DS90CR285. DS90CR2856 ,DS90CR287.DS90CR288.   精典的Cameralink接口芯片。              那么FPGA接这些芯片的时候,给的时序可以参考Cameralink标准定义进行。下面进行一些举例说明。 (1)mono8, 8Tap 黑白图像              该模式下,一个时钟输出8个x方向的相邻像素,占用A、B、C、D、E、F、G、H共8个通道,A通道输出tap1,B通道输出tap2,C通道输出tap3,D通道输出tap4,E通道输出tap5,F通道输出tap6,G通道输出tap7,H通道输出tap8,如下图所示。 具体时序图,如下所示。              图像分辨率为m行和n列,那么一个FVAL信号包括m个LVAL信号,一个LVAL信号包括n/8个CLOCK时钟。 数据输出的有效期或者无效期,时钟信号CLOCK一直有效,时钟

ROS新手必看:5分钟搞定rqt工具箱核心插件配置(附无人机调试实战)

ROS实战:从零到一掌握rqt工具箱,打造你的机器人数据可视化中枢 如果你刚开始接触ROS,面对海量的节点、话题和消息数据,是不是感觉像在黑暗中摸索?命令行里的文本输出虽然精确,但缺乏直观性,调试一个简单的PID参数可能都要反复重启节点、查看日志,效率低下。这正是rqt工具箱设计的初衷——为ROS开发者提供一套基于Qt的图形化“瑞士军刀”,将复杂的数据流变成一目了然的图表和图形界面。 我记得第一次用rqt_plot可视化无人机角速度数据时,那种“原来如此”的顿悟感。不再需要去解析冗长的命令行数字,期望值与实际值的曲线对比直接在屏幕上展开,超调、震荡、响应延迟变得肉眼可见。rqt不仅仅是几个工具,它更像是一个可自由拼装的工作台,你可以把计算图、参数配置、数据曲线、日志信息全部整合在一个窗口里,形成专属的调试仪表盘。本文将带你超越基础的“点击操作”,深入理解rqt的插件化架构,并结合作者真实的无人机调试经验,展示如何高效配置核心插件,解决常见的“灰色加号”等棘手问题,最终让你能灵活运用rqt应对各种机器人开发场景。 1. 重新认识rqt:不止于工具集,而是可视化框架 很多人把rq

基于深度学习的无人机航拍小目标检测算法研究

基于深度学习的无人机航拍小目标检测算法研究

本项目针对无人机航拍场景下的小目标检测问题,基于 YOLO11 系列模型,在 VisDrone 2019 数据集上进行训练与优化,并提供了完整的检测系统桌面应用,支持图片、视频、摄像头的实时检测与训练指标可视化。 一、项目概述 无人机航拍图像具有目标尺度小、密集分布、多尺度混合等特点,传统检测算法难以取得理想效果。本项目采用 Ultralytics YOLO11 框架,结合 VisDrone 数据集进行训练,实现了对行人、车辆等 10 类交通相关目标的高效检测,并配套开发了基于 PyQt6 的桌面应用,便于模型验证与日常使用。 二、数据集 2.1 数据集简介 本项目使用 VisDrone 2019-DET 数据集,由天津大学机器学习与数据挖掘实验室 AISKYEYE 团队发布,对应 ICCV 2019 "Vision

用YOLOv12官版镜像做无人机巡检项目分享

用YOLOv12官版镜像做无人机巡检项目分享 在电力巡检一线干了五年,我见过太多这样的场景:飞手操控无人机绕着高压铁塔盘旋,屏幕里画面晃动、细节模糊,肉眼辨认绝缘子裂纹得反复放大三遍;后台算法团队却在抱怨——“模型跑不起来”,不是显存爆了就是推理卡顿,更别说在机载边缘盒子上实时运行。直到把整套系统换成 YOLOv12 官版镜像,整个流程变了:从起飞到识别缺陷,全程无需人工干预;单帧处理压到 2.4ms;连最老款的 Jetson Orin NX 都能稳稳跑满 30FPS。 这不是参数堆砌的纸上谈兵,而是我们刚在南方某省电网完成的实测项目。今天不讲论文、不列公式,就聊一件事:怎么用现成的 YOLOv12 镜像,把一套靠谱的无人机智能巡检系统真正跑通、落地、用起来。 1. 为什么是 YOLOv12?不是 v8、v10,也不是 RT-DETR 先说结论:它解决了无人机巡检中最痛的三个硬约束——低延迟、小体积、强鲁棒性。