drze7794 2018-03-02 09:01
浏览 123
已采纳

Go的堆接口实现的优先级队列的大小限制

In Java there is a PriorityQueue with size attribute. I'm expecting the same here (if I'm not wrong).

Use case: Read millions of data one by one and send it to a priority queue. I want only the top 5 calculated elements so I want a heap/priority queue of size 5 only.

I'm trying to use heap interface to achieve this. As to what I see golang does dynamic array increase but this is not feasible in my case.

I am referring to https://play.golang.org/p/wE413xwmxE

How can I achieve this?

  • 写回答

1条回答 默认 最新

  • douhan5547 2018-03-02 14:59
    关注

    If you just want top M smallest elements from N elements then use the heap that would give you the biggest element and prune the heap whenever its size goes over value M. Then take elements from the heap in reverse order.

    package main
    
    import (
        "container/heap"
        "fmt"
        "math/rand"
    )
    
    type IntHeap []int
    
    func (h IntHeap) Len() int           { return len(h) }
    func (h IntHeap) Less(i, j int) bool { return h[i] > h[j] }
    func (h IntHeap) Swap(i, j int)      { h[i], h[j] = h[j], h[i] }
    
    func (h *IntHeap) Push(x interface{}) {
        *h = append(*h, x.(int))
    }
    
    func (h *IntHeap) Pop() interface{} {
        old := *h
        n := len(old)
        x := old[n-1]
        *h = old[0 : n-1]
        return x
    }
    
    const (
        n = 1000000
        m = 5
    )
    
    func main() {
        h := &IntHeap{}
        heap.Init(h)
    
        for i := 0; i < n; i++ {
            x := rand.Intn(n)
            heap.Push(h,x)
            if h.Len() > m {
                heap.Pop(h)
            }
        }
    
        r := make([]int, h.Len())
        for i := len(r) - 1; i >= 0; i-- {
            r[i] = heap.Pop(h).(int)
        }
        fmt.Printf("%v
    ", r)
    }
    

    This algorithm has memory complexity of M and time complexity of N + N * log M + M * log M.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥30 YOLO检测微调结果p为1
  • ¥20 求快手直播间榜单匿名采集ID用户名简单能学会的
  • ¥15 DS18B20内部ADC模数转换器
  • ¥15 做个有关计算的小程序
  • ¥15 MPI读取tif文件无法正常给各进程分配路径
  • ¥15 如何用MATLAB实现以下三个公式(有相互嵌套)
  • ¥30 关于#算法#的问题:运用EViews第九版本进行一系列计量经济学的时间数列数据回归分析预测问题 求各位帮我解答一下
  • ¥15 setInterval 页面闪烁,怎么解决
  • ¥15 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题