go leecode 全排列

采坑:过程中使用的是分片,分片是引用拷贝

 

func permute(nums []int) [][]int {

    var data []int
    var list [][]int

    _, list = getPermute(nums, data, list)
    return list
}

func getPermute(nums []int, data []int, list [][]int) ([]int, [][]int) {

    for indx, num := range nums {

        if len(nums) == 1 {

            // 分片是引用 需要拷贝值写入list
             d := make([]int, len(data))
             copy(d, data)

            list = append(list, append(d, nums...))
        } else if indx == len(nums)-1 {
            data = append(data, num)

            formNums := make([]int, len(nums))
            copy(formNums, nums)

            newNums := append(formNums[:indx])

            data, list = getPermute(newNums, data, list)
        } else {
            data = append(data, num)
            // 原列表不能改变
            formNums := make([]int, len(nums))
            copy(formNums, nums)

            newNums := append(formNums[:indx], formNums[indx+1:]...)
            data, list = getPermute(newNums, data, list)
        }
    }
    if len(data) > 0 {
        data = data[:len(data)-1]
    }

    return data, list

}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值