summaryrefslogtreecommitdiff
path: root/vendor/modernc.org/mathutil/permute.go
diff options
context:
space:
mode:
authorLibravatar kim <89579420+NyaaaWhatsUpDoc@users.noreply.github.com>2021-08-29 15:41:41 +0100
committerLibravatar GitHub <noreply@github.com>2021-08-29 16:41:41 +0200
commited462245730bd7832019bd43e0bc1c9d1c055e8e (patch)
tree1caad78ea6aabf5ea93c93a8ade97176b4889500 /vendor/modernc.org/mathutil/permute.go
parentMention fixup (#167) (diff)
downloadgotosocial-ed462245730bd7832019bd43e0bc1c9d1c055e8e.tar.xz
Add SQLite support, fix un-thread-safe DB caches, small performance f… (#172)
* Add SQLite support, fix un-thread-safe DB caches, small performance fixes Signed-off-by: kim (grufwub) <grufwub@gmail.com> * add SQLite licenses to README Signed-off-by: kim (grufwub) <grufwub@gmail.com> * appease the linter, and fix my dumbass-ery Signed-off-by: kim (grufwub) <grufwub@gmail.com> * make requested changes Signed-off-by: kim (grufwub) <grufwub@gmail.com> * add back comment Signed-off-by: kim (grufwub) <grufwub@gmail.com>
Diffstat (limited to 'vendor/modernc.org/mathutil/permute.go')
-rw-r--r--vendor/modernc.org/mathutil/permute.go39
1 files changed, 39 insertions, 0 deletions
diff --git a/vendor/modernc.org/mathutil/permute.go b/vendor/modernc.org/mathutil/permute.go
new file mode 100644
index 000000000..e2ff3d615
--- /dev/null
+++ b/vendor/modernc.org/mathutil/permute.go
@@ -0,0 +1,39 @@
+// 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
+}