标题:循环队列问题
只看楼主
gaoxiaoyijia
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2009-5-13
结帖率:100%
 问题点数:0 回复次数:2 
循环队列问题
循环队列长度的计算公式 Length=(rear - front + Maxsize) % Maxsize 中为什么要进行取余计算
rear是尾指针front是头指针,Maxsize为存储空间长度


搜索更多相关主题的帖子: 队列 
2010-04-09 23:36
寒风中的细雨
Rank: 17Rank: 17Rank: 17Rank: 17Rank: 17
等 级:贵宾
威 望:66
帖 子:1710
专家分:8645
注 册:2009-9-15
得分:0 
循环队列中 当对头出队列 队尾进队列 存在front的值大于rear的情况
此时rear-front 的值就为负的  而加上Maxsize后 就刚好补过来
   假设1:Maxsize=5     rear=0, front=4,  rear是指向队尾的下一个单元 也就是现在的rear指的单元没有存放数据因为front=4,若是front=0 就不是这种情况。 此时的队列长度1 ,如果不采用
       Length=(rear - front + Maxsize) % Maxsize的方法  得到错误的结果是 rear-front = -4 而采用刚才的算法就真好是 1。
   假设2:Maxsize=5   rear=3, front=0, 此时的对长是3,  Length=(rear - front + Maxsize) % Maxsize算的的结果也是3。相当 Length = rear - front + 0


    所以, 之所以在rear-front后面加上Maxsize是为了避免假设1 当中的情况产生, 而,后面取余 是为了在避免假设1:的基础上去避免假设2:的产生。 综合来说,单存在假设1 可以不要取余,单存在假设2 在计算队长的时候可以什么都不要,只要rear-front 即可。
              
2010-04-10 08:24
LegendofMine
该用户已被删除
得分:0 
提示: 作者被禁止或删除 内容自动屏蔽
2010-04-28 12:29



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-302380-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.136433 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved