数据结构循环队列问题
假设以数组Q[0。。M-1]存放循环队列的元素,以域变量REAR(初始REAR=0)和LENGTH分别指示循环队列中队尾元素的位置和队列中元素个数,问队列满的条件和队头元...
假设以数组Q[0。。M-1]存放循环队列的元素,以域变量REAR(初始REAR=0)和LENGTH分别指示循环队列中队尾元素的位置和队列中元素个数,问队列满的条件和队头元素所在位置。
展开
展开全部
Q[0。。M-1],M个元素的数组。队列为空时,队头FRONT与队尾REAR相等。每插入一个元素,REAR增1;每删除一个元素,FRONT减1。
作循环队列用时不能将其填满,因为满了的话REAR标志又与队头标志FRONT相等了,与队列为空时的标志一样,冲突了。
所以要牺牲一个元素的空间了。LENGTH最大只能为M-1;队列满时,(REAR+1)%M == FRONT 就可以用作队列满的判断依据。
经过多次的入队和出队操作后队头和队尾元素都是不确定的,只能在队列满时根据队尾的位置推算。
作循环队列用时不能将其填满,因为满了的话REAR标志又与队头标志FRONT相等了,与队列为空时的标志一样,冲突了。
所以要牺牲一个元素的空间了。LENGTH最大只能为M-1;队列满时,(REAR+1)%M == FRONT 就可以用作队列满的判断依据。
经过多次的入队和出队操作后队头和队尾元素都是不确定的,只能在队列满时根据队尾的位置推算。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询