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.

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

报告相同问题?

悬赏问题

  • ¥15 微信小程序协议怎么写
  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看