1 Star 0 Fork 0

ljfirst/algo-go-sdk

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
options.go 1.55 KB
一键复制 编辑 原始数据 按行查看 历史
ljfirst 提交于 2023-07-04 23:35 +08:00 . feat: PriorityQueue
package C
/**
* @author ljfirst
* @version V1.0
* @date 2023/7/4 21:23
* @author-Email ljfirst@mail.ustc.edu.cn
* @blogURL https://blog.csdn.net/ljfirst
* @description 优先队列 Option
* */
type Options func(*Option)
type Option struct {
IsSmallHeap bool // 是否小顶堆
LimitSize int // 限制容量-不可以扩容
MaxSize int // 最大容量-可以扩容
FromHighToLow bool // true表示从高到低排序,默认 false 表示从低到高排序
HeadInsert bool // 头插法,默认false是尾插法
GT GT
Change Change
Compare Compare
}
func NewOptions(options ...Options) *Option {
opt := &Option{
IsSmallHeap: false,
LimitSize: 0,
MaxSize: 8,
GT: ArrayGT,
}
for _, option := range options {
option(opt)
}
return opt
}
func WithHeadInsert(headInsert bool) Options {
return func(o *Option) {
o.HeadInsert = headInsert
}
}
func WithFromHighToLow(fromHighToLow bool) Options {
return func(o *Option) {
o.FromHighToLow = fromHighToLow
}
}
func WithQueueType(smallHeap bool) Options {
return func(o *Option) {
o.IsSmallHeap = smallHeap
}
}
func WithMaxSize(maxSize int) Options {
return func(o *Option) {
o.MaxSize = maxSize
}
}
func WithLimitSize(limitSize int) Options {
return func(o *Option) {
o.LimitSize = limitSize
}
}
func WithGT(gt GT) Options {
return func(o *Option) {
o.GT = gt
}
}
func WithChange(change Change) Options {
return func(o *Option) {
o.Change = change
}
}
func WithCompare(compare Compare) Options {
return func(o *Option) {
o.Compare = compare
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/ljfirst/algo-go-sdk.git
git@gitee.com:ljfirst/algo-go-sdk.git
ljfirst
algo-go-sdk
algo-go-sdk
v1.0.3

搜索帮助