mirror of
				https://github.com/ehang-io/nps
				synced 2025-10-27 01:16:10 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			22 lines
		
	
	
		
			505 B
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			22 lines
		
	
	
		
			505 B
		
	
	
	
		
			Go
		
	
	
	
	
	
| package sheap
 | |
| 
 | |
| type IntHeap []int64
 | |
| 
 | |
| 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{}) {
 | |
| 	// Push and Pop use pointer receivers because they modify the slice's length,
 | |
| 	// not just its contents.
 | |
| 	*h = append(*h, x.(int64))
 | |
| }
 | |
| 
 | |
| func (h *IntHeap) Pop() interface{} {
 | |
| 	old := *h
 | |
| 	n := len(old)
 | |
| 	x := old[n-1]
 | |
| 	*h = old[0 : n-1]
 | |
| 	return x
 | |
| }
 | 
