当前位置: 首页 > article >正文

循环队列中的求队列长度公式怎么来的?【数学角度】

循环队列中的队列长度怎么来的?

引入

在一个循环队列中,队列的元素个数可以通过头指针(Front,通常用F表示)和尾指针(Rear,通常用R表示)来计算。假设队列的存储空间大小为n,队列中元素的个数(即队列长度)可以通过以下公式计算:

队列长度 = (R−F+n)%n

这个公式的含义是:尾指针R减去头指针F,加上n再取模n。这是因为R - F可能为负数,通过加上n保证结果始终为正数,然后再对n取模,确保结果在队列容量范围内。

image-20231206151511455

例题 + 图示

  • 情况1 R > F

image-20231206151341795

  • 情况2 R < F

image-20231206151403359


上述我们已经会使用循环队列求队列的公式了,那么这个公式是如何来的呢 ?

知其然,亦知其所以然

数学角度理解

从数学的角度来理解循环队列中队列长度的计算涉及到模运算(余数运算)的概念。首先,我们先了解一下模运算的定义:

给定整数a和正整数n,a mod n的值就是a除以n的余数。这可以表示为:

image-20231206150722632

这样的定义保证了 0 ≤ a mod n < n


在循环队列中,头指针F和尾指针R的差值(R - F)可以表示队列的长度。然而,由于队列是循环的,当尾指针R超过了队列的最大容量n时,尾指针需要回到队列的开头,即回到0的位置。这时候 RF 就可能变成负数。也就是我上述列举的例题 1.2 的情况, R-F < 0

为了得到正确的队列长度,我们使用模运算。具体来说,我们加上n,这样就将负数变成了正数,然后再取模n,确保结果在合法范围内。这就是为什么队列长度的计算公式是 (RF+n)%n 的原因。


总结

通过这种方式,我们能够正确地计算出循环队列中的队列长度,考虑了队列循环的特殊性。这种数学定义和计算方式有助于在实际编程中处理循环队列时保持正确性。

在这里插入图片描述


http://www.kler.cn/news/159676.html

相关文章:

  • 【华为OD题库-068】找出经过特定点的路径长度-java
  • 【数电笔记】07-基本和复合逻辑运算
  • 『亚马逊云科技产品测评』活动征文|基于亚马逊云EC2搭建OA系统
  • uniapp打包的h5项目多了接口调用https://api.next.bspapp.com/client
  • 1.1美术理论基础
  • 快手数仓面试题附答案
  • 流量异常-挂马造成百度收录异常关键词之解决方案(虚拟主机)
  • python内存处理和常见的内存泄漏场景
  • 【从删库到跑路 | MySQL数据库总结篇】JDBC编程
  • 【论文】F1的单位是%还是1,mAP的单位是%还是1?答:F1的单位是1,mAP的单位是%
  • flutter的CircularProgressIndicator基本使用
  • 【UGUI】实现背包的常用操作
  • USTC Fall2023 高级人工智能期末考试回忆版
  • 力扣:196. 删除重复的电子邮箱(Python3)
  • go第三方包发布(短精细)
  • InnoDB存储引擎体系结构中的各个组件是如何协同工作的?
  • WVP-RPO开源项目搭建实践
  • 苹果TF签名全称TestFlight签名,需要怎么做才可以上架呢?
  • C++笔试题之回文数的判断
  • 【Redis6快速深入学习04】Redis字符串(String)的使用和原理
  • 【分布式微服务专题】从单体到分布式(一、SpringCloud项目初步升级)
  • FAQ:Reference篇
  • Android各版本引入的重要安全机制介绍
  • nodeJS爬虫-爬取虎嗅新闻
  • vos3000怎样设置落地的优先级
  • HXDSP2441-I2C(Inter-Integrated Circuit)
  • 麒麟系统图形化应用自启
  • 【微信小程序开发】学习小程序的模块化开发(自定义组件和分包加载)
  • MinIo 的操作与使用和避坑
  • Mysql行格式(记录格式)详解