力扣例题(循环队列)

链接

. - 力扣(LeetCode)

描述

思路

我们使用数组来创建循环队列

数组的大小我们就额外对开辟一块空间

MyCircularQueue(k)

开辟一个结构体,存放队列的相关数据

分别为size,数组指针_a,起始位置head,结束位置tail

注意:我们开辟数组空间时需要多开辟一位用于判断空与满

队列为空或者满

开始时head与tail都指向0(head为开始位置,tail为结束位置的下一个位置)

这样的话,数组为空即为tail==head

数组为满,我们拿size=5为例子,由于多开辟了一块空间,数组满时,head=0,tail为最后一个元素的下一个位置,最后一个元素下标为4,tail=5,那么满的情况即为(tail+1)%(size+1)==head

Front

如果数组不为空,那么返回起始位置的元素

Rear

如果数组不为空

返回tail节点的前一个位置

如果tail>0,那么尾节点即为tail-1

tail==0,尾节点为size

enQueue(value)

首先判断队列有没有满,满了返回false,没满则继续

插入元素我们只需要对尾节点进行赋值同时尾节点后移即可

deQueue()

首先判断队列是否为空,为空则返回false

不为空,我们给tail往前移即可,不需要对值进行更改,因为插入操作会将值给覆盖掉

代码

typedef struct {int* a;int head;int tail;int size;
} MyCircularQueue;MyCircularQueue* myCircularQueueCreate(int k) {MyCircularQueue* mn = (MyCircularQueue*)malloc(sizeof(MyCircularQueue));mn->size = k;mn->a = (int*)malloc(sizeof(int) * (mn->size + 1));mn->head = 0;mn->tail = 0;return mn;
}bool myCircularQueueIsEmpty(MyCircularQueue* obj) {return obj->head== obj->tail;
}bool myCircularQueueIsFull(MyCircularQueue* obj) {return (obj->tail+1)%(obj->size+1)==obj->head;
}bool myCircularQueueEnQueue(MyCircularQueue* obj, int value) {if (!myCircularQueueIsFull(obj)) {obj->a[obj->tail] = value;obj->tail = ((obj->tail) + 1) % (obj->size + 1);return true;}return false;
}bool myCircularQueueDeQueue(MyCircularQueue* obj) {if (!myCircularQueueIsEmpty(obj)) {obj->head = ((obj->head) + 1) % (obj->size + 1);return true;}return false;
}int myCircularQueueFront(MyCircularQueue* obj) {if (!myCircularQueueIsEmpty(obj))return obj->a[obj->head];return -1;
}int myCircularQueueRear(MyCircularQueue* obj) {int a;if (!myCircularQueueIsEmpty(obj)) {if (obj->tail > 0)a = obj->tail - 1;elsea = obj->size;return obj->a[a];}return -1;
}void myCircularQueueFree(MyCircularQueue* obj) {free(obj->a);free(obj);
}

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

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

相关文章

(四)Spring教程——控制反转或依赖注入与Java的反射技术

IoC的底层实现技术是反射技术,目前Java、C#、PHP 等语言均支持反射技术。 在运行状态中,对于任意一个类,都能够获取到这个类的所有属性和方法;对任意一个对象,都能够调用它的任意方法和属性(包括私有的方法…

手撸XXL-JOB(四)——远程调用定时任务

Java Socket网络编程 网络编程是Java编程中的重要组成部分,包括服务端和客户端两部分内容。Socket是Java网络编程的基本组件之一,用于在应用程序之间提供双向通信,Socket提供了一种标准的接口,允许应用程序通过网络发送和接收数据…

项目实施方案:多点异地机动车典型系统试验状态可视监控系统

目录 一、需求分析 1.1项目背景 1.2项目概述 二、系统优势 2.1兼容性能力强 2.2接入协议多样 2.3并发能力强 2.3.1 单平台参数 2.3.2 多平台性能参数 2.4 系统稳定性 三、建设目标 3.1安全性 3.2可扩展性 3.3易用性 3.4兼容性 3.5 响应能力 四、系统整体解决方…

Nodejs笔记2

模块化 模块化初体验 模块暴露数据 导入模块 fs 写绝对路径 require写相对路径不会受到影响 ./../不能省略 js 和json文件后缀可以省略 如果存在 命名相同的js和json文件,优先导入js文件 导入文件夹时的情况 require导入模块的基本流程 commonJS模块…

上位机图像处理和嵌入式模块部署(树莓派4b和电源供给)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing 163.com】 前面,我们说过pc电脑和嵌入式设备,两者都可以实现相同的软件功能。但是和pc相比较,嵌入式设备不仅价格更便宜&a…

24深圳杯C题18页高质量论文+可执行代码+图表

比赛题目的完整版思路可执行代码数据参考论文都会在第一时间更新上传的,大家可以参考我往期的资料,所有的资料数据以及到最后更新的参考论文都是一次付费后续免费的。注意:(建议先下单占坑,因为随着后续我们更新资料数…

129.哈希表:有效的字母异位词(力扣)

242. 有效的字母异位词 - 力扣(LeetCode) 题目描述 代码解决以及思路 这个方法的时间复杂度为O(N),其中N是字符串的长度,空间复杂度为O(1)(因为辅助数组的大小是固定的26)。 class Solution { public:bo…

智能终端RK3568主板在智慧公交条形屏项目的应用,支持鸿蒙,支持全国产化

基于AIoT-3568A的智慧公交条形屏,可支持公交线路动态展示,语音到站提醒,减少过乘、漏乘的情况,有效提高了公交服务效率和质量,为乘客提供了更舒适、更安全和更方便的出行体验,为城市的发展增添了新的活力。…

在idea中使用vue

一、安装node.js 1、在node.js官网(下载 | Node.js 中文网)上下载适合自己电脑版本的node.js压缩包 2、下载完成后进行解压并安装,一定要记住自己的安装路径 一直点击next即可,这部选第一个 3、安装成功后,按住winR输入…

嵌入式科普(16)c语言函数参数的传递方式

目录 一、概述 二、C函数参数 2.1 一张图讲清 2.2 按数据类型分类: 2.2.1 基本数据类型参数: 2.2.2 数组参数: 2.2.3 结构体参数: 2.2.4 指针参数: 2.2.5 函数指针参数: 2.3 按传递方式分类&…

具身触觉社区| “大咖面对面”第一期活动顺利举行

4月27日,由中国人工智能学会认知系统与信息处理专委会组织的“具身触觉社区”第一期“大咖面对面”分享活动顺利举行,我们邀请到了美国麻省理工学院(MIT)博士、视触觉传感器的奠基人、GelSight指尖传感器发明人李瑞老师为社区带来…

原生小程序开发如何使用 tailwindcss

原生小程序开发如何使用 tailwindcss 原生小程序开发如何使用 tailwindcss 前言什么是 weapp-tailwindcss ?0. 准备环境以及小程序项目1. 安装与配置 tailwindcss 0. 使用包管理器安装 tailwindcss1. 在项目目录下创建 postcss.config.js 并注册 tailwindcss2. 配置 tailwind…