• Stars
    star
    850
  • Rank 51,740 (Top 2 %)
  • Language
    Go
  • License
    MIT License
  • Created almost 10 years ago
  • Updated 23 days ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Golang implementation of Radix trees

go-radix Build Status

Provides the radix package that implements a radix tree. The package only provides a single Tree implementation, optimized for sparse nodes.

As a radix tree, it provides the following:

  • O(k) operations. In many cases, this can be faster than a hash table since the hash function is an O(k) operation, and hash tables have very poor cache locality.
  • Minimum / Maximum value lookups
  • Ordered iteration

For an immutable variant, see go-immutable-radix.

Documentation

The full documentation is available on Godoc.

Example

Below is a simple example of usage

// Create a tree
r := radix.New()
r.Insert("foo", 1)
r.Insert("bar", 2)
r.Insert("foobar", 2)

// Find the longest prefix match
m, _, _ := r.LongestPrefix("foozip")
if m != "foo" {
    panic("should be foo")
}

More Repositories

1

go-socks5

SOCKS5 server in Golang
Go
1,844
star
2

bloomd

C network daemon for bloom filters
C
1,238
star
3

libart

Adaptive Radix Trees implemented in C
C
745
star
4

hlld

C network daemon for HyperLogLogs
C
446
star
5

go-proxyproto

Golang package to handle HAProxy Proxy Protocol
Go
199
star
6

circbuf

Golang circular (ring) buffer
Go
168
star
7

relay

Golang framework for simple message passing using an AMQP broker
Go
130
star
8

go-chord

Golang implementation of the Chord protocol
Go
130
star
9

consul-api

Golang API client for Consul
Go
123
star
10

erl-rstar

An Erlang implementation of the R*-tree spacial data structure
Erlang
59
star
11

pypred

A Python library for simple evaluation of natural language predicates
Python
57
star
12

c-minheap-array

Implements a Min-Heap / Priority Queue in C using a simple array.
C
54
star
13

counterd

A lightweight daemon for counting unique events using Redis and PostgreSQL
Go
35
star
14

consul-kv

Golang K/V client for Consul
Go
33
star
15

DjangoProjectExample

An example Django project
Python
28
star
16

c-minheap-indirect

Implements a Min-Heap / Priority Queue in C using an indirection table for memory efficiency.
C
28
star
17

go-hlld

Golang client for HyperLogLog daemon (hlld)
Go
21
star
18

cse473-ai-csp

A Constraint Satisfaction Solver (CSP) using Backtracking and Forward Checking
Java
21
star
19

cuda-hll

A CUDA accelerated utility for using HyperLogLog's for cardinality estimation
18
star
20

teles

An Erlang network service for manipulating geographic data
Erlang
15
star
21

bloomd_ring

Provides a Riak core interface to bloomd to allow for horizontal scalability and high availability
Erlang
14
star
22

Erlang-Naive-Bayes-Movies

An Erlang naive bayes text classifier to classify movie reviews as positive or negative.
Erlang
13
star
23

pyhlld

A Python driver for the hlld server
Python
10
star
24

ememcached

An Erlang Implementation of the Memcached binary protocol
Erlang
9
star
25

erl-bloomd

An Erlang driver for speaking the Bloomd network protocol
Erlang
8
star
26

DotFiles

Misc. dot files
Vim Script
3
star
27

pyteles

A Python client for the Teles server
Python
1
star