当前位置: 首页 > article >正文

【golang】使用container/heap官方包实现一个优先队列

golang实现优先队列,以前写的一个简单例子,现上传备份


package test

import (
	"container/heap"
	"fmt"
)

func Test() {
	// 测试一下任务队列
	// 1、首先测试是标准任务队列,队列之中的元素是结构体Person
	pq := &AgePQ{}
	heap.Init(pq)
	ages := []int{2, 3, 1, 6, 5}
	for i := range ages {
		tem := &Person{Age: ages[i]}
		heap.Push(pq, tem)
	}
	// 查看pq情况
	fmt.Println(heap.Pop(pq).(*Person).Age) //6
	fmt.Println(heap.Pop(pq).(*Person).Age) //5
	fmt.Println(heap.Pop(pq).(*Person).Age) //3
	fmt.Println(heap.Pop(pq).(*Person).Age) //2
	fmt.Println(heap.Pop(pq).(*Person).Age) //1
	// 这里要注意一下pop方法是在队列的顶进行的操作,如果是升序,则pop出的是最小的值,降序则pop出的是最大的值
	fmt.Println("—————我是传说中的分割线————")
	// 2、接下来测试的是int元素所组成的优先队列
	pq1 := &PQ_of_int{}
	heap.Init(pq1)
	for i := range ages {
		heap.Push(pq1, ages[i])
	}
	fmt.Println(heap.Pop(pq1).(int)) //1
	fmt.Println(heap.Pop(pq1).(int)) //2
	fmt.Println(heap.Pop(pq1).(int)) //3
	fmt.Println(heap.Pop(pq1).(int)) //5
	fmt.Println(heap.Pop(pq1).(int)) //6
	// 测试结果显示,这两个类型的优先队列都是能完成的
}

// 结构体优先队列
type Person struct {
	Age int
}
type AgePQ []*Person

func (pq AgePQ) Len() int {
	return len(pq)
}
func (pq AgePQ) Less(i, j int) bool {
	// 我们这按照一个降序
	return pq[i].Age > pq[j].Age
}
func (pq AgePQ) Swap(i, j int) {
	pq[i], pq[j] = pq[j], pq[i]
}

// 两个队列独有的方法
func (pq *AgePQ) Push(x any) {
	item := x.(*Person)
	*pq = append(*pq, item)
}
func (pq *AgePQ) Pop() any {
	if pq.Len() == 0 {
		return nil
	}
	last := (*pq)[pq.Len()-1]
	*pq = (*pq)[:(pq.Len() - 1)]
	return last
}

// 简单的int组成的优先队列
type PQ_of_int []int

func (pq PQ_of_int) Len() int {
	return len(pq)
}
func (pq PQ_of_int) Less(i, j int) bool {
	// 这里是一个升序
	return pq[i] < pq[j]
}
func (pq PQ_of_int) Swap(i, j int) {
	pq[i], pq[j] = pq[j], pq[i]
}
func (pq *PQ_of_int) Push(x any) {
	*pq = append(*pq, x.(int))
}
func (pq *PQ_of_int) Pop() any {
	if pq.Len() == 0 {
		return nil
	}
	last := (*pq)[pq.Len()-1]
	*pq = (*pq)[:pq.Len()-1]
	return last
}

主要测试了两个优先队列,一个队列是针对Person结构体,第二个队列单纯就是int切片

需要注意以下几个点:

1、pop和push行为最好不要直接调用,而是借助heap.Pop()这样的方法

2、pop行为可能在js当中表示删除数组的最后一个值,这里pop行为是可以自定义的,我将pop行为定义成删除队列最后的值,而真实运行起来,却是删除队列的Top值,比如这里的PQ_of_int,我在Less方法之中定义的是一个升序,但是最后pop出来的确实12356这样的顺序,可能这里有些说法我不是很清楚


http://www.kler.cn/a/292587.html

相关文章:

  • 数据产品:深度探索与案例剖析
  • 微信小程序中使用离线版阿里云矢量图标
  • 深入探索React合成事件(SyntheticEvent):跨浏览器的事件处理利器
  • 【VIM】vim 常用命令
  • HarmonyOS的@State装饰器的底层实现
  • 文件输入输出——NOI
  • 鼠标在虚拟机virtualbox里面不显示/消失,如何解决?
  • Stable Diffusion训练LoRA模型参数详细说明(阿里巴巴堆友AI)
  • List、Set、Map中的方法使用、Stream流、Collections工具类
  • 如何使用 Lua 脚本进行更复杂的网络请求,比如 POST 请求?
  • 一个开源、注重隐私且支持自托管的网站分析工具
  • 数据结构 哈希表 五大排序算法 二分查找(折半查找)
  • GitHub精选|8 个强大工具,助力你的开发和探究工作
  • Android studio 导出 release 版本的 .aar 文件
  • PyTorch 创建数据集
  • 相机检查内参 外参
  • Github Codespaces Cmake项目使用
  • 实战项目十的更新代码
  • 三极管三模电
  • 代码随想录算法训练营第五十九天 | 图论part09
  • 2024数学建模国赛选题建议+团队助攻资料
  • 优化理论及应用精解【4】
  • GNU/Linux - 进程关联的控制终端
  • centos7.9搭建mysql5.6
  • 无论是速卖通、敦煌网、国际站,自养号测评就是提高曝光的利器!
  • 支付宝直付通与微信收付通分账产品:功能差异与适用场景