内容简介:转载请注明出处:队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表。进行插入操作的端称为队尾,进行删除操作的端称为队头。数据结构里的队列就是模仿现实中的排队。
转载请注明出处: 数据结构——Golang实现队列
Golang
1. 介绍
队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表。进行插入操作的端称为队尾,进行删除操作的端称为队头。
数据结构里的队列就是模仿现实中的排队。
1) 新来的都排在队尾;
2) 最前面的办理业务后离队,后面一个跟上。
根据特点,计算机砖家就归纳以下队列结构。
image.png
2. Golang 实现
2.1. 队列结构
同前文的栈一样,在这里,我把队列拆分为两个部分,容器和链表,容器用结构体实现,链表用单链表,当然大家也可以用其他链表结构,甚至数组来实现。
这里的例子,也是使用单链表实现的。
// Queue 队列信息 type Queue struct{ list *SingleList }
2.2. 队列初始化
队列的初始化,也即是内部的链表初始化:
// Init 队列初始化 func (q *Queue)Init() { q.list = new(SingleList) q.list.Init() }
2.3. 入队(Enqueue)
从队尾添加数据到队列,称为入队(Enqueue)
// Enqueue 进入队列 func (q *Queue) Enqueue(data interface{}) bool{ return q.list.Append(&SingleNode{Data:data}) }
2.4. 出队(Dequeue)
从队头取出数据称为出队或出列(Dequeue)
// Dequeue 出列 func (q *Queue) Dequeue() interface{}{ node := q.list.Get(0) if node == nil{ return nil } q.list.Delete(0) return node.Data }
2.5. 查看队头元素(Peek)
查看队头元素,但不取出:
// Peek 查看队头信息 func (q *Queue)Peek() interface{}{ node := q.list.Get(0) if node == nil{ return nil } return node.Data }
2.6. 获取队列长度(Size)
获取当前队列中所有元素的数量:
// Size 获取队列长度 func (q *Queue) Size() uint{ return q.list.Size }
3. 单元测试
package dstr import( "testing" ) func TestQueue_Init(t *testing.T) { q := new(Queue) q.Init() } func TestQueue_Enqueue(t *testing.T){ q := new(Queue) q.Init() q.Enqueue(1) if 1 == q.Size(){ t.Log("queue size and enquqeuesuccess") } else { t.Error("queue size and enqueue failed") } } func TestQueue_Dequeue(t *testing.T){ q := new(Queue) q.Init() d1 := q.Dequeue() if d1 == nil{ t.Log("empty queue dequeue success") } else { t.Error("empty queue dequeue failed") } q.Enqueue(1) d := q.Dequeue() if 1 == d.(int) && q.Size() == 0{ t.Log("queue dequeue success") } else { t.Error("queue dequeue failed") } } func TestQueue_Peek(t *testing.T){ q := new(Queue) q.Init() d1 := q.Peek() if d1 == nil{ t.Log("empty queue peek success") }else { t.Error("empty queue peek failed") } q.Enqueue(1) d := q.Peek() if 1 == d.(int) && q.Size() == 1{ t.Log("queue peek success") } else { t.Error("queue peek failed") } }
4. 源码
5. 参考文献
完
转载请注明出处: 数据结构——Golang实现队列
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Linux/UNIX系统编程手册
Michael Kerrisk / 孙剑 许从年 董健、孙余强 郭光伟 陈舸 / 人民邮电出版社 / 2014-1 / 158
《linux/unix系统编程手册(上、下册)》是介绍linux与unix编程接口的权威著作。linux编程资深专家michael kerrisk在书中详细描述了linux/unix系统编程所涉及的系统调用和库函数,并辅之以全面而清晰的代码示例。《linux/unix系统编程手册(上、下册)》涵盖了逾500个系统调用及库函数,并给出逾200个程序示例,另含88张表格和115幅示意图。 《li......一起来看看 《Linux/UNIX系统编程手册》 这本书的介绍吧!
RGB转16进制工具
RGB HEX 互转工具
Markdown 在线编辑器
Markdown 在线编辑器