forked from wufenggirl/LeetCode-in-Golang
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathminimum-number-of-refueling-stops.go
executable file
·72 lines (57 loc) · 1.4 KB
/
minimum-number-of-refueling-stops.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
package problem0871
import "container/heap"
// 把题目换一种说法,就好理解了。
// 汽车在开往目的地的过程中,
// 会在沿路的加油站,都买上一箱汽油,
// 每个加油站的汽油大小还不一样。
// 汽车每次没油的时候,就在买过的汽油中,挑一箱加上。
// 问,汽车达到目的地的时候,最少需要加几次油?
func minRefuelStops(target int, startFuel int, stations [][]int) int {
size := len(stations)
gases := make(intHeap, 0, size)
miles := startFuel
stops := 0
i := 0
for {
if miles >= target {
// 到达了目的地
return stops
}
// 路过加油站的时候,买汽油
for i < size && stations[i][0] <= miles {
heap.Push(&gases, stations[i][1])
i++
}
if len(gases) == 0 {
break
}
maxGas := heap.Pop(&gases).(int)
stops++
miles += maxGas
}
return -1
}
// intHeap 实现了 heap 的接口
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{}) {
// Push 使用 *h,是因为
// Push 增加了 h 的长度
*h = append(*h, x.(int))
}
func (h *intHeap) Pop() interface{} {
// Pop 使用 *h ,是因为
// Pop 减短了 h 的长度
res := (*h)[len(*h)-1]
*h = (*h)[:len(*h)-1]
return res
}