golang中怎么利用leetcode 实现一个平衡二叉树
发表于:2025-02-01 作者:千家信息网编辑
千家信息网最后更新 2025年02月01日,这期内容当中小编将会给大家带来有关golang中怎么利用leetcode 实现一个平衡二叉树,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。输入一棵二叉树的根节点,判
千家信息网最后更新 2025年02月01日golang中怎么利用leetcode 实现一个平衡二叉树
这期内容当中小编将会给大家带来有关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
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 实现一个平衡二叉树了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注行业资讯频道。
子树
高度
循环
内容
就是
知识
示例
节点
问题
分析
专业
世界
两个
个数
中小
代码
内容丰富
思路
文章
时候
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
山东远盾网络技术
杭州麦海拾贝网络技术有限公司
2010数据库表之间的关系
农行软件开发中心总行
电子网络技术专业都望了
软件工程 网络软件开发
西宁市网络安全测评中心
nac软件开发平台
东营应用软件开发咨询
苏州智能设备软件开发
网络安全的核心
服务器磁盘管理命令
信息化及网络安全试题及答案
客户端调用服务器函数
ios数据库操作
浙江语音网络技术服务五星服务
唐山企业管理软件开发团队
设立数据库
陇南bim软件开发工程
机器人笔记软件开发
服务器管理作用是什么
数据库后的总结反思
幼儿网络安全舞蹈完整版
软件开发专业职校包就业吗
ros软件开发平台
中国的网络安全情况汇报
网络安全哪家好一点
网络安全攻防靶场
文字朗读软件开发
网络安全知识读本在线考试