【Go 语法】不能在一个函数声明的内部再声明另一个函数

问题描述

如下代码:

我在定义函数 isSymmetric 时,因为要调用到函数 com_tree,所以我就在函数 isSymmetric 内部定义了函数 com_tree:

func isSymmetric(root *TreeNode) bool {

    if root == nil{
        return true
    }else{
        return com_tree(root.Left,root.Right)
    }

	func com_tree(lefttree *TreeNode,righttree *TreeNode) bool {
	        if lefttree == nil && righttree == nil{  //左右子树都为nil
	            return true
	        }else if lefttree == nil || righttree == nil{ //左右子树有一个为nil
	            return false
	        }else if lefttree.Val == righttree.Val{   //左右子树都不为nil
	            //递归调用
	            return com_tree(lefttree.Left , righttree.Right) && com_tree(lefttree.Right , righttree.Left)
	        }else{
	            return false
	        }
	}

    return false
}

报错:

Line 17: Char 10: syntax error: unexpected com_tree, expecting ( (solution.go)

含义:

不被期待的 com_tree,期待 (


原因分析

Go 语言定义函数的时候不能嵌套!!!!!

也就是说,不能在一个函数定义中再定义一个函数。

上例中,不能在定义函数 isSymmetric 的内部再定义函数 com_tree。


解决方案

应该分别定义函数 isSymmetric 和函数 com_tree:

func isSymmetric(root *TreeNode) bool {

    if root == nil{
        return true
    }else{
        return com_tree(root.Left,root.Right)
    }
    return false
}


func com_tree(lefttree *TreeNode,righttree *TreeNode) bool {
        if lefttree == nil && righttree == nil{  //左右子树都为nil
            return true
        }else if lefttree == nil || righttree == nil{ //左右子树有一个为nil
            return false
        }else if lefttree.Val == righttree.Val{   //左右子树都不为nil
            //递归调用
            return com_tree(lefttree.Left , righttree.Right) && com_tree(lefttree.Right , righttree.Left)
        }else{
            return false
        }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值