您的第一个示例缺少复合文字的类型。


由于您使用了值,因此可以使用(在Go Playgroundstring上尝试):


test := [][]string{

    {"6", ".", ".", "1", "9", "5", ".", ".", "."},

    {".", "9", "8", ".", ".", ".", ".", "6", "."},

    {"8", ".", ".", ".", "6", ".", ".", ".", "3"},

    {"4", ".", ".", "8", ".", "3", ".", ".", "1"},

    {"7", ".", ".", ".", "2", ".", ".", ".", "6"},

    {".", "6", ".", ".", ".", ".", "2", "8", "."},

    {".", ".", ".", "4", "1", "9", ".", ".", "5"},

    {".", ".", ".", ".", "8", ".", ".", "7", "9"},

}

如果您想要一个“字节矩阵”,请使用可以分配给byte类型变量的常量文字,例如符文文字(在Go Playground上尝试):


test := [][]byte{

    {'6', '.', '.', '1', '9', '5', '.', '.', '.'},

    {'.', '9', '8', '.', '.', '.', '.', '6', '.'},

    {'8', '.', '.', '.', '6', '.', '.', '.', '3'},

    {'4', '.', '.', '8', '.', '3', '.', '.', '1'},

    {'7', '.', '.', '.', '2', '.', '.', '.', '6'},

    {'.', '6', '.', '.', '.', '.', '2', '8', '.'},

    {'.', '.', '.', '4', '1', '9', '.', '.', '5'},

    {'.', '.', '.', '.', '8', '.', '.', '7', '9'},

}

如果将行枚举为字符串,并使用[]byte() 转换将行转换为(在Go Playground[]byte上尝试),则可以实现相同的目的:


test := [][]byte{

    []byte("6..195..."),

    []byte(".98....6."),

    []byte("8...6...3"),

    []byte("4..8.3..1"),

    []byte("7...2...6"),

    []byte(".6....28."),

    []byte("...419..5"),

    []byte("....8..79"),

}

最后一个版本可能更令人赏心悦目并且更容易修改,但请注意,它仅在您在行中使用 ASCII 字符时才有效,因为高于 127 的字符在 UTF-8 编码中具有多字节(这就是 Go 存储字符串的方式在内存中),因此将其转换string为[]byte将导致比它拥有的字符更多的字节。