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

学习 时间:2026-04-03 13:21:42 阅读:2776
为什么(rear+1)%max==front时,队列就满了,比如数组max=3,a[front]=0,a[1]=1,a[2]2=2,rear=0,不相等啊

最佳回答

帅气的钢笔

傲娇的哑铃

2026-04-03 13:21:42

画一个圈圈,自己数哈!标准的形式是(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】,
就是这样,

最新回答共有2条回答

  • 整齐的手机
    回复
    2026-04-03 13:21:42

    画一个圈圈,自己数哈!标准的形式是(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】,就是这样,

上一篇 英文名Victoria怎么样?

下一篇 燃气油炸锅的缺点是什么