网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

golang中怎么利用leetcode实现一个平衡二叉树

这期内容当中小编将会给大家带来有关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+1       return 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 main
import (  "fmt"  "time")
func main() {  c := make(chan bool)  go testSelectFor(c)
 c <- true  c <- false  close(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实现一个平衡二叉树
文章路径:http://bjjierui.cn/article/ppsego.html