Summary
- 什么是环形队列
- 实现环形队列图示过程
- golang版本代码实现过程
- 参考全部代码
什么是环形队列
在一个指定大小的数组里循环写入数据,借用二个指针分别实现入队标记与出队标记.也体现了指针的大好用处,请深入体会.大有裨益.
如图所示,一个环形队列.含有二个指针: 队列头指针,队列尾指针.
实现环形队列图示过程
初始化一个数组大小为6的环形队列, 头指针front=0, 尾指针rear=0, 刚好front=rear =0的状态,表示环形队列为空.
2.向环形队列里插入1个元素,则rear指针移动一格,front=0,rear=1
3.继续添加a2,a3,a4,a5元素,rear指针指到末尾处,front=0, reat=5
4.如果再继续添加a6元素,则rear=6,大于数组大小,发生数组溢出.
5.如上图所示添加a6时,rear指针发生溢出.我们使用一个小技巧,当rear=6时与数组大小6进行取模, (rear+1) % maxLen,让rear指针回到开始处rear=0,问题来了,我们无法判断数组是否满"text-align: center">
6.解决以上问题有三种办法,我们采用第3种方法实现.
使用第3种方法: 即当(rear+1) % maxLen == front时,判断环形数组满,则无法添加元素
golang版代码实现过程
a. 定义环形数据结构
type CycleQueue struct { data []interface{} //存储空间 front int //前指针,前指针负责弹出数据移动 rear int //尾指针,后指针负责添加数据移动 cap int //设置切片最大容量 }
b.初始化环形队列
func NewCycleQueue(cap int) *CycleQueue { return &CycleQueue{ data: make([]interface{}, cap), cap: cap, front: 0, rear: 0, } }
c. 入队操作
//入队操作 //判断队列是否队满,队满则不允许添加数据 func (q *CycleQueue) Push(data interface{}) bool { //check queue is full if (q.rear+1)%q.cap == q.front { //队列已满时,不执行入队操作 return false } q.data[q.rear] = data //将元素放入队列尾部 q.rear = (q.rear + 1) % q.cap //尾部元素指向下一个空间位置,取模运算保证了索引不越界(余数一定小于除数) return true }
d.出队操作
//出队操作 //需要考虑: 队队为空没有数据返回了 func (q *CycleQueue) Pop() interface{} { if q.rear == q.front { return nil } data := q.data[q.front] q.data[q.front] = nil q.front = (q.front + 1) % q.cap return data }
e:求当前的环形队列长度
//因为是循环队列, 后指针减去前指针 加上最大值, 然后与最大值 取余 func (q *CycleQueue) QueueLength() int { return (q.rear - q.front + q.cap) % q.cap }
参考全部代码
github
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。