Golang 基于数组、链表实现队列

本文介绍如何使用数组和链表数据结构实现队列的基本功能,包括添加(Add)、移除(Remove)和获取顶部元素(Top)。通过示例展示了`ListQueue`和`LinkQueue`的创建、操作和队列大小的维护。
摘要由CSDN通过智能技术生成

使用数组、队列实现简单的队列能力

  • Top() 返回队列第一个元素
  • Add() 入队
  • Remove(data int) 出队
package main

func main() {
	lq := NewListQueue()
	lq.Add(10)
	lq.Add(20)
	lq.Add(25)
	lq.Add(30)
	lq.Add(100)
	lq.Remove()
	lq.Remove()
	lq.Remove()
	lq.Remove()
	fmt.Println(lq.size)

	lq.Add(123)
	fmt.Println(lq.size)
	fmt.Println(lq.Top())
}

type Queue interface {
	Top() int
	Add() int
	Remove(data int)
}

type ListQueue struct {
	data []int
	size int
	lock sync.Mutex
}

type LinkQueue struct {
	root *LinkNode
	size int
	lock sync.Mutex
}

type LinkNode struct {
	data int
	next *LinkNode
}

func NewListQueue() *ListQueue {
	return &ListQueue{
		data: make([]int, 0),
		size: 0,
		lock: sync.Mutex{},
	}
}

func (lq *ListQueue) Top() int {
	return lq.data[0]
}

func (lq *ListQueue) Add(data int) {
	lq.lock.Lock()
	defer lq.lock.Unlock()

	lq.size++
	lq.data = append(lq.data, data)
}

func (lq *ListQueue) Remove() int {
	lq.lock.Lock()
	defer lq.lock.Unlock()

	lq.size--
	head := lq.data[0]
	lq.data = lq.data[1:len(lq.data)]
	return head
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值