40 lines
1009 B
Go
40 lines
1009 B
Go
|
// Copyright (c) 2014 The mathutil Authors. All rights reserved.
|
||
|
// Use of this source code is governed by a BSD-style
|
||
|
// license that can be found in the LICENSE file.
|
||
|
|
||
|
package mathutil // import "modernc.org/mathutil"
|
||
|
|
||
|
import (
|
||
|
"sort"
|
||
|
)
|
||
|
|
||
|
// PermutationFirst generates the first permutation of data.
|
||
|
func PermutationFirst(data sort.Interface) {
|
||
|
sort.Sort(data)
|
||
|
}
|
||
|
|
||
|
// PermutationNext generates the next permutation of data if possible and
|
||
|
// return true. Return false if there is no more permutation left. Based on
|
||
|
// the algorithm described here:
|
||
|
// http://en.wikipedia.org/wiki/Permutation#Generation_in_lexicographic_order
|
||
|
func PermutationNext(data sort.Interface) bool {
|
||
|
var k, l int
|
||
|
for k = data.Len() - 2; ; k-- { // 1.
|
||
|
if k < 0 {
|
||
|
return false
|
||
|
}
|
||
|
|
||
|
if data.Less(k, k+1) {
|
||
|
break
|
||
|
}
|
||
|
}
|
||
|
for l = data.Len() - 1; !data.Less(k, l); l-- { // 2.
|
||
|
}
|
||
|
data.Swap(k, l) // 3.
|
||
|
for i, j := k+1, data.Len()-1; i < j; i++ { // 4.
|
||
|
data.Swap(i, j)
|
||
|
j--
|
||
|
}
|
||
|
return true
|
||
|
}
|