multiway merge

This commit is contained in:
Gregory 2022-01-02 23:55:38 +02:00
parent bee59b5d0b
commit f85fd63c74

View file

@ -1,6 +1,8 @@
package priority_queue package priority_queue
import ( import (
"io"
"strings"
"testing" "testing"
"github.com/stretchr/testify/assert" "github.com/stretchr/testify/assert"
@ -156,3 +158,34 @@ func TestIndexChange(t *testing.T) {
assert.Equal(t, 10, pq.top()) assert.Equal(t, 10, pq.top())
} }
func TestMultiwayMerge(t *testing.T) {
// ordered "streams"
firstStream := strings.NewReader("ABCFGIIZ")
secondStream := strings.NewReader("BDHPQQ")
thirdStream := strings.NewReader("ABEFJN")
allStreams := []*strings.Reader{firstStream, secondStream, thirdStream}
expected := "AABBBCDEFFGHIIJNPQQZ"
actual := ""
pq := NewIPQ(func(t1, t2 string) bool { return t1 > t2 }, len(allStreams)+1)
for i, stream := range allStreams {
rune, _, _ := stream.ReadRune()
pq.insert(i+1, string(rune))
}
for !pq.isEmpty() {
actual += string(pq.top())
streamIndex := pq.topKey()
pq.remove()
rune, _, err := allStreams[streamIndex-1].ReadRune()
if err != io.EOF {
pq.insert(streamIndex, string(rune))
}
}
assert.Equal(t, expected, actual)
}