怎么在golang中实现一个环形队列-创新互联

这期内容当中小编将会给大家带来有关怎么在golang中实现一个环形队列,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

创新互联建站成都网站建设按需制作,是成都网站设计公司,为水泥搅拌车提供网站建设服务,有成熟的网站定制合作流程,提供网站定制设计服务:原型图制作、网站创意设计、前端HTML5制作、后台程序开发等。成都网站制作热线:028-86922220

什么是环形队列

在一个指定大小的数组里循环写入数据,借用二个指针分别实现入队标记与出队标记.也体现了指针的大好用处,请深入体会.大有裨益.

如图所示,一个环形队列.含有二个指针: 队列头指针,队列尾指针.

怎么在golang中实现一个环形队列

实现环形队列图示过程

初始化一个数组大小为6的环形队列, 头指针front=0, 尾指针rear=0, 刚好front=rear =0的状态,表示环形队列为空.

怎么在golang中实现一个环形队列

2.向环形队列里插入1个元素,则rear指针移动一格,front=0,rear=1

怎么在golang中实现一个环形队列

3.继续添加a2,a3,a4,a5元素,rear指针指到末尾处,front=0, reat=5

怎么在golang中实现一个环形队列

4.如果再继续添加a6元素,则rear=6,大于数组大小,发生数组溢出.

怎么在golang中实现一个环形队列

5.如上图所示添加a6时,rear指针发生溢出.我们使用一个小技巧,当rear=6时与数组大小6进行取模, (rear+1) % maxLen,让rear指针回到开始处rear=0,问题来了,我们无法判断数组是否满?因为初始化时front=rear=0, 现在数组满也是front=rear=0

怎么在golang中实现一个环形队列

6.解决以上问题有三种办法,我们采用第3种方法实现.

怎么在golang中实现一个环形队列

使用第3种方法: 即当(rear+1) % maxLen == front时,判断环形数组满,则无法添加元素

怎么在golang中实现一个环形队列

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
}

上述就是小编为大家分享的怎么在golang中实现一个环形队列了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注创新互联成都网站设计公司行业资讯频道。

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


本文名称:怎么在golang中实现一个环形队列-创新互联
分享网址:http://pwwzsj.com/article/dgpdej.html