为什么(rear+1)%max==front时,队列就满了,比如数组max=3,a[front]=0

发布时间:2021-02-20 10:43:53

为什么(rear+1)%max==front时,队列就满了,比如数组max=3,a[front]=0,a[1]=1,a[2]2=2,rear=0,不相等啊

网友回答

画一个圈圈,自己数哈!标准的形式是(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】,
就是这样,
以上问题属网友观点,不代表本站立场,仅供参考!