为什么(rear+1)%max==front时,队列就满了,比如数组max=3,a[front]=0,a[1]=1,a[2]2=2,rear=0,不相等啊
1个回答
展开全部
画一个圈圈,自己数哈!标准的形式是(rear-front+1)%max=0.
要是按您的说法呀!
max=3,a[front]=0,a[1]=1,a[2]2=2,也就是rear=2,而不是等于0,要等于零,就重复占用了,也就是rear=front 这是重复位置了。rear->front.
有数组,a[3]={1,1,1}和数组a[3]={1,1,}
前面一个是满的(rear-front+1)%max=【(2-0+1)%3=0】,对吧。
后面一个不是满的吧(rear-front+1)%max=【(1-0+1)%3=2】,
就是这样,
要是按您的说法呀!
max=3,a[front]=0,a[1]=1,a[2]2=2,也就是rear=2,而不是等于0,要等于零,就重复占用了,也就是rear=front 这是重复位置了。rear->front.
有数组,a[3]={1,1,1}和数组a[3]={1,1,}
前面一个是满的(rear-front+1)%max=【(2-0+1)%3=0】,对吧。
后面一个不是满的吧(rear-front+1)%max=【(1-0+1)%3=2】,
就是这样,
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询