今天刷 leetcode 解决一个获取二叉树深度算法题的时候我对我的解法正确性很确定,但是结果就是不对,因为刚接触 leetcode,二叉树输入都是数组形式给出的,我不知道怎么构造出树来,不知道怎么调试,所以这个问题卡了我半天,真的不知所措。后面我用同样的 python 解法都没问题,肉眼排查了半天才找到疑点。于是自己写了下面的 demo,才知道问题出在哪。
那么问题来了,不执行以下代码代码你脑解出答案么?
demo:
package main
import "fmt"
func main() {
a := []int{1}
b := a
a = a[:0]
a = append(a, 2)
a = append(a, 3)
fmt.Println(a, b)
}
其实这个问题专门拿出来说可能比较容易避开这个坑,但是实际情况可能很容易被忽视掉。
有问题版本:
func maxDepth(root *TreeNode) int {
if root == nil{
return 0
}
depth := 0
stack := []*TreeNode{root}
for ;len(stack) != 0;{
depth ++
c := stack
stack = stack[:0]
for _, v := range c{
if v.Left != nil{
stack = append(stack, v.Left)
}
if v.Right != nil{
stack = append(stack, v.Right)
}
}
}
return depth
}
正确版本:
func maxDepth(root *TreeNode) int {
if root == nil{
return 0
}
depth := 0
stack := []*TreeNode{root}
for ;len(stack) != 0;{
depth ++
nxtSt := make([]*TreeNode, 0)
for _, v := range stack{
if v.Left != nil{
nxtSt = append(nxtSt, v.Left)
}
if v.Right != nil{
nxtSt = append(nxtSt, v.Right)
}
}
stack = nxtSt
}
return depth
}
希望能帮到同样是 golang 新手的你^_^
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.