比较Golang中的二叉树。我的回答是错的

时间:2015-04-16 22:10:49

标签: pointers go binary-tree

我要比较Golang中的二叉树。但我的回答是错误的。需要第三只眼睛来帮助。 感谢。

package main

import(
    "fmt"
)

type TreeNode struct {
    val int
    left *TreeNode
    right *TreeNode

}

func isSameTree(p *TreeNode , q *TreeNode ) (bool){
    if p == nil && q == nil {
        return true
    } 
    if p != nil && q == nil{
        return false;
    }
    if p ==nil && q != nil {
        return false;
    }
    if (p.val == q.val) && (isSameTree(p.left,q.left)) && (isSameTree(p.right ,q.left)){
        return true;
    } else {
        return false;
    }
}
func main(){
    p := &TreeNode{val: 1}
    p.left = &TreeNode{val: 2}
    p.right = &TreeNode{val: 3}

    q := &TreeNode{val: 1}
    q.left = &TreeNode{val: 2}
    q.right = &TreeNode{val: 3}

    isSame := isSameTree(p,q)
    fmt.Println("is same?: ", isSame)
}

转到此代码的操场链接: https://play.golang.org/p/mTX3aBxh6_

1 个答案:

答案 0 :(得分:1)

这一行有一个小错误;

 if (p.val == q.val) && (isSameTree(p.left,q.left)) && (isSameTree(p.right ,q.left)){

应该是;

 if (p.val == q.val) && (isSameTree(p.left,q.left)) && (isSameTree(p.right ,q.right)){

如果在第二次调用isSameTree时没有看到差异,那么当它应该是q.right时,你会传递q.left。

更新了go play; https://play.golang.org/p/ul9ijG9HLc