代码拉取完成,页面将自动刷新
package main
import (
"fmt"
"os"
)
const N int = 1e6
var count int = 0
func main() {
digits := []int{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}
sorts := make([]int, 0, len(digits))
permutation(sorts, digits)
}
// permutation count计数,初始值为0;n
func permutation(sorts, digits []int) {
lenOfDigits := len(digits)
if lenOfDigits == 1 {
count++
if count == N {
sorts = append(sorts, digits[0])
fmt.Println(sorts)
os.Exit(0)
}
}
for i := 0; i < lenOfDigits; i++ {
nextSorts := sorts
nextSorts = append(nextSorts, digits[i])
nextDigits := make([]int, lenOfDigits-1)
for j := 0; j < lenOfDigits; j++ {
if j < i {
nextDigits[j] = digits[j]
} else if j > i {
nextDigits[j-1] = digits[j]
}
}
if count < N {
permutation(nextSorts, nextDigits)
}
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。