这期内容当中小编将会给大家带来有关golang中怎么利用leetcode 实现一个平衡二叉树,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

专注于为中小企业提供网站制作、网站建设服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业阆中免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了1000+企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。
输入一棵二叉树的根节点,判断该树是不是平衡二叉树。如果某二叉树中任意节点的左右子树的深度相差不超过1,那么它就是一棵平衡二叉树。
示例 1:
给定二叉树 [3,9,20,null,null,15,7]
3
/ \
9 20
/ \
15 7
返回 true 。
示例 2:
给定二叉树 [1,2,2,3,3,null,null,4,4]
1
/ \
2 2
/ \
3 3
/ \
4 4
返回 false 。
限制:
1 <= 树的结点个数 <= 10000
解题思路:
1,对于树一类问题,我们优先想倒递归
2,平衡二叉树是左右子树高度差不超过1
3,那么,包含两个子问题:
A,左子树高度和右子树高度相差不超过1
B,左右子树都是平衡的
4,注意,计算高度的时候,是左右子树的大者+1
代码实现
/*** Definition for a binary tree node.* type TreeNode struct {* Val int* Left *TreeNode* Right *TreeNode* }*/func isBalanced(root *TreeNode) bool {if root==nil{return true}l:=height(root.Left)r:=height(root.Right)if l>r+1 || l+1return false}return isBalanced(root.Left)&&isBalanced(root.Right)}func height(root*TreeNode)int{if root==nil{return 0}l:=height(root.Left)r:=height(root.Right)if l>r{return l+1}return r+1}
golang 知识积累
通常在for循环中,使用break可以跳出循环,但是注意在go语言中,for select配合时,break并不能跳出循环。
package mainimport ("fmt""time")func main() {c := make(chan bool)go testSelectFor(c)c <- truec <- falseclose(c)time.Sleep(time.Duration(2) * time.Second)fmt.Println("Hello, 世界")}func testSelectFor(chExit chan bool) {for {select {case v, ok := <-chExit:if !ok {fmt.Println("close channel 1", v)break}fmt.Println("ch2 val =", v)}}fmt.Println("exit testSelectFor")}
上述就是小编为大家分享的golang中怎么利用leetcode 实现一个平衡二叉树了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注创新互联行业资讯频道。
文章标题:golang中怎么利用leetcode实现一个平衡二叉树
URL链接:http://www.jxjierui.cn/article/ppsego.html


咨询
建站咨询
