7大数据结构之队列篇

1 篇文章 0 订阅
1 篇文章 0 订阅
1、什么是队列

队列是一种先进先出的(First In First Out)的线性表,简称FIFO

示例图:
在这里插入图片描述
在这里插入图片描述

2、数组实现队列
// 创建一个数组队列
type Queue struct {
   list []int
}
// 写入一个值队列
func (q *Queue) EnQueue(val int){
   q.list = append(q.list, val)
}
// 从队列中取出一个值
func (q *Queue) DeQueue()int{
   if len(q.list) == 0 {
   	panic("empty queue")
   }
   val := q.list[0]
   q.list = q.list[1:]
   return val
}
// 测试
func main(){
   q := Queue{}
   q.EnQueue(1)
   r := q.DeQueue()
   fmt.Println(r)
}
3、环形队列和双向队列

1、环形对列
在这里插入图片描述
在这里插入图片描述
2、双向队列
在这里插入图片描述

4、队列的实际应用

迷宫问题
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值