Skip to content

anjiawei1991/go-skiplist

 
 

Repository files navigation

SkipList

ref: https://en.wikipedia.org/wiki/Skip_list

example:

import (
	"fmt"
	"github.com/MaruHyl/go-skiplist"
)

func ExampleSkipList() {
	intCompare := func(a interface{}, b interface{}) int {
		return a.(int) - b.(int)
	}
	l := skiplist.New(intCompare)

	// insert
	l.Insert(3, "value 1")
	l.Insert(1, "value 1")
	l.Insert(2, "value 1")

	// delete
	l.Delete(2)

	// get
	fmt.Println(l.Search(1))

	// foreach
	l.Foreach(func(key interface{}, value interface{}) {
		fmt.Println(key, ":", value)
	})

	// Output:
	// value 1 true
	// 1 : value 1
	// 3 : value 1
}

benchmark:

goos: darwin
goarch: amd64
pkg: github.com/MaruHyl/go-skiplist
BenchmarkSkipList_Insert-12      5000000               424 ns/op
BenchmarkSkipList_Search-12     20000000               76.7 ns/op
BenchmarkSkipList_Delete-12     20000000               90.6 ns/op

Indexable skiplist

TODO

About

SkipList and Indexable skiplist

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 100.0%