mirror of
				https://github.com/superseriousbusiness/gotosocial.git
				synced 2025-10-30 16:32:26 -05:00 
			
		
		
		
	
		
			
	
	
		
			40 lines
		
	
	
	
		
			1,009 B
		
	
	
	
		
			Go
		
	
	
	
	
	
		
		
			
		
	
	
			40 lines
		
	
	
	
		
			1,009 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 | ||
|  | } |