热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

一文搞懂循环队列的不同配置问题

本文主要详细讲解了数据结构中循环队列在3种不同配置下所延申出来的一些问题,而对于链式队列则没什么好说的。注意本文所说的配置是指:什么时候是队空状态,什么时候是队满状态,入队操作怎么




本文主要详细讲解了数据结构中循环队列在3种不同配置下所延申出来的一些问题,而对于链式队列则没什么好说的。


注意本文所说的配置是指:什么时候是队空状态,什么时候是队满状态,入队操作怎么执行,出队操作怎么执行。它们在不同的规定下会体现出不同的形式,这些不同的形式就是队列的配置了。

文章目录

    • 一、正常配置
          • 队空状态:
          • 入队操作:
          • 出队操作:
          • 队满状态:
          • 计算当前队列中元素个数问题:
    • 二、非正常配置1
          • 队空状态:
          • 入队操作:
          • 出队操作:
          • 队满状态:
          • 计算当前队列中元素个数问题:
    • 二、非正常配置2
          • 队空状态:
          • 入队操作:
          • 出队操作:
          • 队满状态:
          • 计算当前队列中元素个数问题:



一、正常配置

正常配置:先移指针,后看数据


队空状态:

在这里插入图片描述


入队操作:

rear先后移一位,然后把数据赋值给rear所指的存储单元。

在这里插入图片描述


出队操作:

front先后移一位,然后取front所指存储单元中的元素。

在这里插入图片描述


队满状态:

我们需要空出一个位置来区分队空和队满这两个状态。

front指向队头元素的前一个位置,rear指向队尾元素。

在这里插入图片描述


计算当前队列中元素个数问题:

在这里插入图片描述

上图当rear(rear+1)+(maxSize-1-front)




二、非正常配置1


队空状态:

在这里插入图片描述


入队操作:

把数据赋值给rear所指的存储单元,然后rear后移一位(先入队元素,再移动指针,和正常配置相反)。

在这里插入图片描述


出队操作:

先取front所指存储单元中的元素,然后front后移一位(和正常配置相反)。

在这里插入图片描述


队满状态:

我们需要空出一个位置来区分队空和队满这两个状态。

front指向队头元素,rear指向队尾元素的后一个位置。

在这里插入图片描述


计算当前队列中元素个数问题:

在这里插入图片描述

上图当rearrear+(maxSize-front)




二、非正常配置2


队空状态:

此非正常配置的队空条件和正常配置的队满条件一样。

在这里插入图片描述


入队操作:

下图先移动指针,当然也可以先入队元素,再移动指针。

在这里插入图片描述


出队操作:

先取front所指存储单元中的元素,然后front后移一位。

在这里插入图片描述


队满状态:

我们需要空出一个位置来区分队空和队满这两个状态。

front指向队头元素,rear指向队尾元素。

在这里插入图片描述


计算当前队列中元素个数问题:

在这里插入图片描述

上图当rear(rear+1)+(maxSize-front)

本配置中rear和front都指向了元素而不同于上面的配置有一个指向空




推荐阅读
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • MQTT技术周报:硬件连接与协议解析
    本周开发笔记重点介绍了在新项目中使用MQTT协议进行硬件连接的技术细节,涵盖其特性、原理及实现步骤。 ... [详细]
  • 探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ... [详细]
  • 作者:守望者1028链接:https:www.nowcoder.comdiscuss55353来源:牛客网面试高频题:校招过程中参考过牛客诸位大佬的面经,但是具体哪一块是参考谁的我 ... [详细]
  • 深入解析TCP/IP五层协议
    本文详细介绍了TCP/IP五层协议模型,包括物理层、数据链路层、网络层、传输层和应用层。每层的功能及其相互关系将被逐一解释,帮助读者理解互联网通信的原理。此外,还特别讨论了UDP和TCP协议的特点以及三次握手、四次挥手的过程。 ... [详细]
  • FinOps 与 Serverless 的结合:破解云成本难题
    本文探讨了如何通过 FinOps 实践优化 Serverless 应用的成本管理,提出了首个 Serverless 函数总成本估计模型,并分享了多种有效的成本优化策略。 ... [详细]
  • 本文详细探讨了HTML表单中GET和POST请求的区别,包括它们的工作原理、数据传输方式、安全性及适用场景。同时,通过实例展示了如何在Servlet中处理这两种请求。 ... [详细]
  • 深入解析Redis内存对象模型
    本文详细介绍了Redis内存对象模型的关键知识点,包括内存统计、内存分配、数据存储细节及优化策略。通过实际案例和专业分析,帮助读者全面理解Redis内存管理机制。 ... [详细]
  • 探讨如何通过高效的数据库查询和排序策略,优化基于GPS位置信息的附近用户搜索功能,以应对大规模用户数据场景。 ... [详细]
  • 本文探讨了哪些数据库支持队列式的写入操作(即一个键对应一个队列,数据可以连续入队),并且具备良好的持久化特性。这类需求通常出现在需要高效处理和存储大量有序数据的场景中。 ... [详细]
  • Netflix利用Druid实现高效实时数据分析
    本文探讨了全球领先的在线娱乐公司Netflix如何通过采用Apache Druid,实现了高效的数据采集、处理和实时分析,从而显著提升了用户体验和业务决策的准确性。文章详细介绍了Netflix在系统架构、数据摄取、管理和查询方面的实践,并展示了Druid在大规模数据处理中的卓越性能。 ... [详细]
  • 深入解析for与foreach遍历集合时的性能差异
    本文将详细探讨for循环和foreach(迭代器)在遍历集合时的性能差异,并通过实际代码示例和源码分析,帮助读者理解这两种遍历方式的不同之处。文章内容丰富且专业,旨在为编程爱好者提供有价值的参考。 ... [详细]
  • 全面解析运维监控:白盒与黑盒监控及四大黄金指标
    本文深入探讨了白盒和黑盒监控的概念,以及它们在系统监控中的应用。通过详细分析基础监控和业务监控的不同采集方法,结合四个黄金指标的解读,帮助读者更好地理解和实施有效的监控策略。 ... [详细]
  • 本文详细介绍了Grand Central Dispatch (GCD) 的核心概念和使用方法,探讨了任务队列、同步与异步执行以及常见的死锁问题。通过具体示例和代码片段,帮助开发者更好地理解和应用GCD进行多线程开发。 ... [详细]
  • 并发编程 12—— 任务取消与关闭 之 shutdownNow 的局限性
    Java并发编程实践目录并发编程01——ThreadLocal并发编程02——ConcurrentHashMap并发编程03——阻塞队列和生产者-消费者模式并发编程04——闭锁Co ... [详细]
author-avatar
好学的程序员
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有