Commit 97eb0623 authored by Rob Pike's avatar Rob Pike

test/chan/sieve2.go: remove container/vector.

R=golang-dev, dsymonds, r
CC=golang-dev
https://golang.org/cl/4918043
parent ab44a814
...@@ -13,7 +13,6 @@ package main ...@@ -13,7 +13,6 @@ package main
import ( import (
"container/heap" "container/heap"
"container/ring" "container/ring"
"container/vector"
) )
// Return a chan of odd numbers, starting from 5. // Return a chan of odd numbers, starting from 5.
...@@ -47,13 +46,28 @@ type PeekCh struct { ...@@ -47,13 +46,28 @@ type PeekCh struct {
ch chan int ch chan int
} }
// Heap of PeekCh, sorting by head values. // Heap of PeekCh, sorting by head values, satisfies Heap interface.
type PeekChHeap struct { type PeekChHeap []*PeekCh
*vector.Vector
}
func (h *PeekChHeap) Less(i, j int) bool { func (h *PeekChHeap) Less(i, j int) bool {
return h.At(i).(*PeekCh).head < h.At(j).(*PeekCh).head return (*h)[i].head < (*h)[j].head
}
func (h *PeekChHeap) Swap(i, j int) {
(*h)[i], (*h)[j] = (*h)[j], (*h)[i]
}
func (h *PeekChHeap) Len() int {
return len(*h)
}
func (h *PeekChHeap) Pop() (v interface{}) {
*h, v = (*h)[:h.Len()-1], (*h)[h.Len()-1]
return
}
func (h *PeekChHeap) Push(v interface{}) {
*h = append(*h, v.(*PeekCh))
} }
// Return a channel to serve as a sending proxy to 'out'. // Return a channel to serve as a sending proxy to 'out'.
...@@ -108,26 +122,26 @@ func Sieve() chan int { ...@@ -108,26 +122,26 @@ func Sieve() chan int {
// Merge channels of multiples of 'primes' into 'composites'. // Merge channels of multiples of 'primes' into 'composites'.
go func() { go func() {
h := &PeekChHeap{new(vector.Vector)} var h PeekChHeap
min := 15 min := 15
for { for {
m := multiples(<-primes) m := multiples(<-primes)
head := <-m head := <-m
for min < head { for min < head {
composites <- min composites <- min
minchan := heap.Pop(h).(*PeekCh) minchan := heap.Pop(&h).(*PeekCh)
min = minchan.head min = minchan.head
minchan.head = <-minchan.ch minchan.head = <-minchan.ch
heap.Push(h, minchan) heap.Push(&h, minchan)
} }
for min == head { for min == head {
minchan := heap.Pop(h).(*PeekCh) minchan := heap.Pop(&h).(*PeekCh)
min = minchan.head min = minchan.head
minchan.head = <-minchan.ch minchan.head = <-minchan.ch
heap.Push(h, minchan) heap.Push(&h, minchan)
} }
composites <- head composites <- head
heap.Push(h, &PeekCh{<-m, m}) heap.Push(&h, &PeekCh{<-m, m})
} }
}() }()
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment