【Go - 小顶堆/大顶堆】

在 Go 语言中,标准库 container/heap 提供了堆(Heap)的实现。可以使用 container/heap 包来实现自己的大顶堆或小顶堆。

小顶堆示例

以下是一个使用 container/heap 包实现的小顶堆示例:

go 复制代码
package main

import (
	"container/heap"
	"fmt"
)

type IntHeap []int

func (h IntHeap) Len() int {
	return len(h)
}
func (h IntHeap) Less(i int, j int) bool {
	return h[i] < h[j]
}
func (h IntHeap) Swap(i int, j int) {
	h[i], h[j] = h[j], h[i]
}
func (h *IntHeap) Pop() interface{} {
	old := *h
	n := len(old)
	x := old[n-1]
	*h = old[0:n-1]
	return x
}
func (h *IntHeap) Push(x interface{}) {
	*h = append(*h, x.(int))
}

func main() {
	h := &IntHeap{2, 1, 5}
	heap.Init(h)
	heap.Push(h, 3)
	m := (*h)[0]
	fmt.Printf("minimum: %d\n", m)
	
	m = heap.Pop(h).(int)
	fmt.Printf("minimum %d\n", m)

	m = heap.Pop(h).(int)
	fmt.Printf("minimum %d\n", m)

}

注意📢 :

  • 涉及到空间变化的,Push,Pop 传参是指针类型,其余的是引用类型。
  • Push,Pop的参数为interface{},在内部再进行类型转换

大顶堆,则只需将Less函数改下,小于改为大于,其余代码一致。

go 复制代码
func (h IntHeap) Less(i int, j int) bool {
	return h[i] > h[j]
}
相关推荐
码云骑士2 小时前
09-Python模块导入机制-sys.path与循环导入的死锁式排查
开发语言·python
星恒随风2 小时前
C++ 模板初阶:从泛型编程、函数模板到类模板,一篇打通基础概念
开发语言·c++·笔记·学习
郝学胜-神的一滴2 小时前
Qt 高级开发 031:QListWidget图标布局实战
开发语言·c++·qt·程序人生·软件构建·用户界面
caimouse2 小时前
Reactos 第 8 章 结构化异常处理 — 8.4 软异常
服务器·开发语言·windows
艾莉丝努力练剑2 小时前
【Qt】界面优化:绘图API
linux·运维·开发语言·网络·qt·tcp/ip·udp
牛油果子哥q2 小时前
队列(Queue)深度精讲,先进先出原理、顺序/链式/循环队列、STL queue底层、栈队列互模拟与面试考点全解
开发语言·c++·面试
聆风吟º2 小时前
【Python编程日志】Python基础数据类型完整梳理
开发语言·python·数据类型
weixin_307779133 小时前
在 Azure 上构建数据库路由与异构整合层:原理、方案与最佳实践
数据库·人工智能·后端·云计算·azure
都说名字长不会被发现3 小时前
Spring Boot Starter 中间件账号密码加密方案设计与实现
java·spring boot·后端·中间件
keykey6.3 小时前
逻辑回归:从回归到分类
开发语言·人工智能·机器学习