91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

golang中怎么利用leetcode 實現一個平衡二叉樹

發布時間:2021-07-06 15:03:26 來源:億速云 閱讀:178 作者:Leah 欄目:大數據

這期內容當中小編將會給大家帶來有關golang中怎么利用leetcode 實現一個平衡二叉樹,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

輸入一棵二叉樹的根節點,判斷該樹是不是平衡二叉樹。如果某二叉樹中任意節點的左右子樹的深度相差不超過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<r{       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 實現一個平衡二叉樹了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

钦州市| 隆昌县| 凤阳县| 鄂托克前旗| 蕲春县| 韩城市| 土默特左旗| 车险| 分宜县| 嘉鱼县| 临颍县| 丹寨县| 怀宁县| 梅河口市| 启东市| 漠河县| 武城县| 东台市| 维西| 榕江县| 博爱县| 五寨县| 乌什县| 东平县| 定结县| 北票市| 桃江县| 共和县| 京山县| 彭山县| 绥中县| 潜山县| 郎溪县| 三门峡市| 云浮市| 秦安县| 论坛| 沈阳市| 广宗县| 河曲县| 南投县|