文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

golang 实现队列

2023-05-16 16:29

关注

队列是一种先进先出(FIFO)的数据结构,常用于解决计算机程序中的各种问题。在 Go 语言中,可以使用标准库中的 container 包来实现队列数据结构。

创建队列

要创建一个队列,我们需要使用 container 包中的 list 库来创建一个列表,并向其中添加元素:

package main

import (
    "container/list"
    "fmt"
)

func main() {
    // 创建一个新的列表
    q := list.New()

    // 向列表中添加元素
    q.PushBack("one")
    q.PushBack("two")
    q.PushBack("three")

    // 遍历列表并打印元素
    for e := q.Front(); e != nil; e = e.Next() {
        fmt.Println(e.Value)
    }
}

在上面的代码中,我们首先导入了 container/list 包,然后使用 list.New() 函数创建了一个新的列表。接下来,使用 q.PushBack() 方法向队列中添加了三个元素,并使用一个 for 循环遍历了列表并打印了元素。

队列操作

除了添加元素,队列还可以执行其他操作。以下是一些常用的队列操作示例:

package main

import (
    "container/list"
    "fmt"
)

func main() {
    // 创建一个新的列表
    q := list.New()

    // 向列表中添加元素
    q.PushBack("one")
    q.PushBack("two")
    q.PushBack("three")

    // 遍历列表并打印元素
    for e := q.Front(); e != nil; e = e.Next() {
        fmt.Println(e.Value)
    }

    // 弹出最前面的元素
    q.Remove(q.Front())

    // 在最前面添加一个元素
    q.PushFront("zero")

    // 遍历列表并打印元素
    for e := q.Front(); e != nil; e = e.Next() {
        fmt.Println(e.Value)
    }
}

在上面的示例中,我们添加了三个元素,并使用 for 循环遍历了列表并打印了元素。接下来,我们使用 q.Remove(q.Front()) 去掉了最前面的元素,并使用 q.PushFront("zero") 在最前面添加了一个新的元素。最后,我们再次使用 for 循环遍历了列表并打印了元素。

实现一个 Queue 结构体

如果您想将队列封装到一个结构体中,可以使用以下代码来创建一个 Queue 结构体:

package main

import (
    "container/list"
)

// 队列结构体
type Queue struct {
    items *list.List
}

// 初始化队列
func NewQueue() *Queue {
    return &Queue{list.New()}
}

// 将元素插入队列尾部
func (q *Queue) Enqueue(value interface{}) {
    q.items.PushBack(value)
}

// 从队列头部移除元素
func (q *Queue) Dequeue() interface{} {
    if q.items.Len() == 0 {
        return nil  // 空队列
    }
    front := q.items.Front()
    q.items.Remove(front)
    return front.Value
}

// 返回队列的长度
func (q *Queue) Len() int {
    return q.items.Len()
}

// 判断队列是否为空
func (q *Queue) IsEmpty() bool {
    return q.Len() == 0
}

在上面的代码中,我们创建了一个 Queue 结构体,并定义了 Enqueue、Dequeue、Len 和 IsEmpty 四个方法。Enqueue 像队列尾部插入元素,Dequeue 从队列头部移除元素,Len 返回队列的长度,IsEmpty 判断队列是否为空。

使用 Queue 结构体

以下是使用 Queue 结构体的示例代码:

package main

import (
    "fmt"
)

func main() {
    q := NewQueue()

    q.Enqueue("one")
    q.Enqueue("two")
    q.Enqueue("three")

    fmt.Println(q.Len(), q.IsEmpty())

    fmt.Println(q.Dequeue())
    fmt.Println(q.Dequeue())

    fmt.Println(q.Len(), q.IsEmpty())

    q.Enqueue("four")

    fmt.Println(q.Len(), q.IsEmpty())

    fmt.Println(q.Dequeue())
    fmt.Println(q.Dequeue())

    fmt.Println(q.Len(), q.IsEmpty())
}

在上面的代码中,我们首先创建了一个新的 Queue 对象 q,并使用 Enqueue 方法向队列中添加三个元素。然后,我们使用 Len 和 IsEmpty 方法查看队列的长度和是否为空,并分别使用 Dequeue 方法移除了前两个元素。接下来,我们再次使用 Len 和 IsEmpty 方法查看队列的长度和是否为空,并向队列中添加了一个新的元素 "four"。最后,我们再次使用 Dequeue 方法移除前两个元素,并使用 Len 和 IsEmpty 检查队列是否为空。

我们可以看到,在 Queue 结构体的帮助下,我们能够清楚、简洁地实现了队列数据结构。

以上就是golang 实现队列的详细内容,更多请关注编程网其它相关文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯