Skip to content

Instantly share code, notes, and snippets.

@sescobb27
Forked from quux00/knuth.go
Last active August 29, 2015 14:21
Show Gist options
  • Save sescobb27/255fcf6161ef1d1de87b to your computer and use it in GitHub Desktop.
Save sescobb27/255fcf6161ef1d1de87b to your computer and use it in GitHub Desktop.
// implements Knuth or Fisher-Yates shuffle
package knuth
import (
"math/rand"
"time"
)
func init() {
rand.Seed(time.Now().UTC().UnixNano())
}
func Shuffle(slc []interface{}) {
N := len(slc)
for i := 0; i < N; i++ {
// choose index uniformly in [i, N-1]
r := i + rand.Intn(N-i)
slc[r], slc[i] = slc[i], slc[r]
}
}
func ShuffleInts(slc []int) {
N := len(slc)
for i := 0; i < N; i++ {
// choose index uniformly in [i, N-1]
r := i + rand.Intn(N-i)
slc[r], slc[i] = slc[i], slc[r]
}
}
func ShuffleStrings(slc []string) {
N := len(slc)
for i := 0; i < N; i++ {
// choose index uniformly in [i, N-1]
r := i + rand.Intn(N-i)
slc[r], slc[i] = slc[i], slc[r]
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment