}
//n个数全排列
//如输入[1 2 3],则返回[123 132 213 231 312 321]
func quanPailie(nums []int) [][]int {
COUNT := len(nums)
//检查
if COUNT == 0 || COUNT > 10 {
panic("Illegal argument. nums size must between 1 and 9.")
}
//如果只有一个数,则直接返回
if COUNT == 1 {
return [][]int{nums}
}
//否则,将最后一个数插入到前面的排列数中的所有位置
return insertItem(quanPailie(nums[:COUNT-1]), nums[COUNT-1])
}
func insertItem(res [][]int, insertNum int) [][]int {
//保存结果的slice
result := make([][]int, len(res)*(len(res[0])+1))
index := 0
for _, v := range res {
for i := 0; i < len(v); i++ {
//在v的每一个元素前面插入新元素
result[index] = insertToSlice(v, i, insertNum)
index++
}
//在v最后面插入新元素
result[index] = append(v, insertNum)
index++
}
return result
}
//将元素value插入到数组nums中索引为index的位置
func insertToSlice(nums []int, index int, value int) []int {
result := make([]int, len(nums)+1)
copy(result[:index], nums[:index])
result[index] = value
copy(result[index+1:], nums[index:])
return result
}
希望本文所述对大家Go语言程序设计有所帮助。









