簡體   English   中英

Golang 切片 append 異常

[英]Golang slice append exception

這是一個leet 代碼問題,當我嘗試用代碼回答時:

package main

import "fmt"

func main() {
    nums := []int{9, 0, 3, 5, 7}
    fmt.Println(subsets(nums))
}

func subsets(nums []int) [][]int {
    var result [][]int
    result = append(result, []int{})
    for _, v := range(nums) {
        for _, rv := range(result) {
            result = append(result, append(rv, v))
        }
    }
    return result
}

Leetcode 告訴我錯誤的答案:

Wrong Answer
Details 
Input
[9,0,3,5,7]
Output
[[],[9],[0],[9,0],[3],[9,3],[0,3],[9,0,3],[5],[9,5],[0,5],[9,0,5],[3,5],[9,3,5],[0,3,5],[9,0,3,7],[7],[9,7],[0,7],[9,0,7],[3,7],[9,3,7],[0,3,7],[9,0,3,7],[5,7],[9,5,7],[0,5,7],[9,0,5,7],[3,5,7],[9,3,5,7],[0,3,5,7],[9,0,3,7,7]]
Expected
[[],[9],[0],[0,9],[3],[3,9],[0,3],[0,3,9],[5],[5,9],[0,5],[0,5,9],[3,5],[3,5,9],[0,3,5],[0,3,5,9],[7],[7,9],[0,7],[0,7,9],[3,7],[3,7,9],[0,3,7],[0,3,7,9],[5,7],[5,7,9],[0,5,7],[0,5,7,9],[3,5,7],[3,5,7,9],[0,3,5,7],[0,3,5,7,9]]

output slice index 15,本來應該是[9,0,3,5],結果卻是[9,0,3,7]。 所以我嘗試通過 go playgroud 在線運行這段代碼,答案是同樣的錯誤,然后我在調試模式下在 goland 中運行這段代碼,我發現當我制作切片append([9,0,3], 7) , output 分片索引15同時變化。

我本地go env: go version go1.17.6 windows/amd64

我只是golang的初學者,誰能解釋一下這種情況? 非常感謝你。

ps:我嘗試使用自爆代碼來恢復同樣的問題,但我失敗了。

package main

import "fmt"

func main() {
    a := [][]int{{}, {9}, {0}, {9, 0}, {3}, {9, 3}, {0, 3}, {9, 0, 3}, {5}, {9, 5}, {0, 5}, {9, 0, 5}, {3, 5}, {9, 3, 5}, {0, 3, 5}, {9, 0, 3, 5}}
    i := 7
    for _, v := range a {
        // fmt.Println(a)
        a = append(a, append(v, i))
        // fmt.Println(a)
    }
    fmt.Println(a)
}

result:
[[] [9] [0] [9 0] [3] [9 3] [0 3] [9 0 3] [5] [9 5] [0 5] [9 0 5] [3 5] [9 3 5] [0 3 5] [9 0 3 5] [7] [9 7] [0 7] [9 0 7] [3 7] [9 3 7] [0 3 7] [9 0 3 7] [5 7] [9 5 7] [0 5 7] [9 0 5 7] [3 5 7] [9 3 5 7] [0 3 5 7] [9 0 3 5 7]]

您在某些切片中重復使用相同的支持數組,因為如果有剩余容量,這就是append所做的。 一個簡單的解決方法是將append(rv, v)替換為append(append([]int{}, rv...), v) ,創建一個全新的切片。 另一種方法是通過將切片限制到其當前長度來強制 append 分配一個新的支持數組: append(rv[:len(rv):len(rv)], v)

帶有工作代碼的游樂場鏈接: https://go.dev/play/p/Gc-yF5KQOAO

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM