我正在尝试使用 Golang 解决一些动态编程问题。我写了一个函数
func main() {
fmt.Println(HowSum(5, []int{1, 2, 5}))
}
func HowSum(targetNum int, numbers []int) []int {
retAry = make([][]int, targetNum+1)
retAry[0] = make([]int, 0)
for i := 0; i <= targetNum; i++ {
if retAry[i] != nil {
for _, num := range numbers {
if i+num <= targetNum {
fmt.Print("Before:", i, " round, num =", num, retAry, "\n")
retAry[i+num] = append(retAry[i], num)
fmt.Print("After :", i, " round, num =", num, retAry, "\n\n")
}
}
}
}
return retAry[targetNum]
}
部分结果如下。
...
Before:3 round, num =2 [[] [1] [1 1] [1 1 1] [1 1 1 1] [5]]
After :3 round, num =2 [[] [1] [1 1] [1 1 1] [1 1 1 2] [1 1 1 2]]
...
[1 1 1 2 1]
当程序将 retAry[5] 从 [5] 替换为 [1 1 1 2] 时,retAry[4] 中的数组从 [1 1 1 1] 更改为 [1 1 1 2]。发生什么事?
但是,如果替换 retAry[i+num] = append(retAry[i], num)为retAry[i+num] = append([]int{num}, retAry[i]...),我可以得到正确的答案。
...
Before:3 round, num =2 [[] [1] [1 1] [1 1 1] [1 1 1 1] [5]]
After :3 round, num =2 [[] [1] [1 1] [1 1 1] [1 1 1 1] [2 1 1 1]]
...
[1 1 1 1 1]
谁能帮助解释我犯了什么错误?
代码在这里
海绵宝宝撒
相关分类