当前位置: 首页 > news >正文

LeetCode543题:二叉树的直径(python3)

在这里插入图片描述
代码思路:
先递归调用左儿子和右儿子求得它们为根的子树的深度 L和 R ,则该节点为根的子树的深度即为max(L,R)+1。该节点的 dnode值为L+R+1

递归搜索每个节点并设一个全局变量 ans记录 dnode的最大值,最后返回 ans-1 即为树的直径。

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:def diameterOfBinaryTree(self, root: Optional[TreeNode]) -> int:self.ans = 1def depth(node):# 访问到空节点了,返回0if not node: return 0 # 左儿子为根的子树的深度L = depth(node.left) # 右儿子为根的子树的深度R = depth(node.right)# 计算d_node即L+R+1 并更新ansself.ans = max(self.ans,L+R+1)# 返回该节点为根的子树的深度return max(L,R)+1 depth(root)return self.ans-1
http://www.lryc.cn/news/317191.html

相关文章:

  • zabbix 7.0编译部署教程
  • Oracle Linux 8.9 安装 Python 3.11.8 和 Miniconda
  • Docker 配置阿里云镜像加速器
  • [Linux][CentOs][Mysql]基于Linux-CentOs7.9系统安装并配置开机自启Mysql-8.0.28数据库
  • 实用指南!2024年度计划怎么写?工作学习必备!
  • js的事件有哪些?
  • Mock.js 基本语法与应用笔记
  • vue从零到一创建项目?
  • 安装PyTorch详细过程
  • 使用Rust开发小型搜索引擎
  • 2024.3.13
  • schedule() , schedule_work() 以及schedule_timeout_interruptible()区别
  • AWS入门实践-AWS CLI工具的使用介绍
  • Xterminal:未来的终端体验
  • “光谱视界革新:ChatGPT在成像光谱遥感中的智能革命“
  • Docker Register 搭建私有镜像仓库
  • 蓝桥杯真题讲解:三国游戏(贪心)
  • docker之自己制作jdk镜像
  • 基于SpringBoot的农产品特色供销系统(蔬菜商城)
  • 【性能】如何计算 Web 页面的 TTI 指标
  • 大模型交互-超拟人合成
  • 第十四届蓝桥杯蜗牛
  • 分布式定时任务调度xxl-job
  • 自动化运维利器Ansible基础(环境部署)
  • 微服务自动化管理初步认识与使用
  • 使用Docker管理linux容器
  • CTR之行为序列建模用户兴趣:DIEN
  • 1960-2020年全球双边迁移数据库(Global Bilateral MigrationDatabase)
  • OpenGL-贴纸方案
  • 【性能测试】移动测试md知识总结第1篇:移动端测试课程介绍【附代码文档】