2019-05-08 02:42:51 +00:00
|
|
|
# structure
|
|
|
|
|
2019-06-17 02:21:14 +00:00
|
|
|
暂时没时间整理, 后期才整理完整
|
2019-07-18 03:06:39 +00:00
|
|
|
|
|
|
|
## PriorityQueue
|
|
|
|
|
|
|
|
``` golang
|
2019-07-18 06:57:44 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"log"
|
|
|
|
|
|
|
|
"github.com/474420502/focus/compare"
|
|
|
|
pqueuekey "github.com/474420502/focus/priority_queuekey"
|
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
pq := pqueuekey.New(compare.Int)
|
|
|
|
pq.Push(1, 1)
|
|
|
|
pq.Push(4, 4)
|
|
|
|
pq.Push(5, 5)
|
|
|
|
pq.Push(6, 6)
|
|
|
|
pq.Push(2, 2) // pq.Values() = [6 5 4 2 1]
|
|
|
|
log.Println(pq.Values())
|
|
|
|
value, _ := pq.Pop() // value = 6
|
|
|
|
log.Println(value)
|
|
|
|
value, _ = pq.Get(1) // value = 1 pq.Values() = [5 4 2 1]
|
|
|
|
log.Println(value)
|
|
|
|
value, _ = pq.Get(0) // value = nil , Get equal to Seach Key
|
|
|
|
log.Println(value)
|
|
|
|
value, _ = pq.Index(0) // value = 5, compare.Int the order from big to small
|
|
|
|
log.Println(value)
|
|
|
|
values := pq.GetRange(2, 5) // values = [2 4 5]
|
|
|
|
log.Println(values)
|
|
|
|
values = pq.GetRange(5, 2) // values = [5 4 2]
|
|
|
|
log.Println(values)
|
|
|
|
values = pq.GetRange(100, 2) // values = [5 4 2]
|
|
|
|
log.Println(values)
|
|
|
|
values3 := pq.GetAround(5) // values3 = [<nil>, 5, 4]
|
|
|
|
log.Println(values3)
|
|
|
|
|
2019-07-21 18:34:57 +00:00
|
|
|
iter := pq.Iterator() // Next 大到小 从root节点起始
|
2019-07-18 06:57:44 +00:00
|
|
|
// log.Println(iter.Value()) 直接使用会报错,
|
2019-07-21 18:02:05 +00:00
|
|
|
iter.ToHead()
|
2019-07-18 07:00:20 +00:00
|
|
|
log.Println(iter.Value()) // 起始最大值. true 5
|
2019-07-21 18:02:05 +00:00
|
|
|
log.Println(iter.Prev(), iter.Value()) // false 5
|
2019-07-18 06:57:44 +00:00
|
|
|
|
2019-07-18 07:00:20 +00:00
|
|
|
// Prev 大到小
|
2019-07-21 18:02:05 +00:00
|
|
|
log.Println(iter.Next(), iter.Value()) // true 4
|
|
|
|
|
|
|
|
|
2019-07-18 06:57:44 +00:00
|
|
|
}
|
2019-07-18 03:06:39 +00:00
|
|
|
```
|