1. Job Roadmap
  2. Home
  3. Problem Set
  4. codenotelist
  5. Forum
  6. course
  7. Shore Share Sessions
  8. Record
  1. Login
  2. Sign Up
  3. Language
    1. English
    2. 한국어
    3. 简体中文
    4. 正體中文
    ZhContent TextSol AI分析

思路

  1. 定义:对于任意节点 uuu,假设它的左子树深度为 LuL_uLu​,右子树深度为 RuR_uRu​,那么经过 uuu 的最长路径长度为 Lu+RuL_u + R_uLu​+Ru​。

  2. 全局直径:我们需要维护一个全局变量 diameter\text{diameter}diameter,初始化为 0。对树中每个节点 uuu,更新:

    diameter=max⁡(diameter,Lu+Ru)\text{diameter} = \max(\text{diameter},L_u + R_u)diameter=max(diameter,Lu​+Ru​)

  3. 递归计算深度:使用后序遍历,对于节点 uuu:

P3410.第2题-二叉树的直径

    1000ms Tried: 29 Accepted: 12 Difficulty: 3 所属公司 : 大疆
    算法与标签>DFS

题目内容

给定一棵二叉树序列,返回该树的直径。 二叉树的直径指树中任意两个节点之间最长路径的长度。这条路径可能经过也可能不经过根节点rootrootroot。

两节点之间路径的长度由它们之间边数表示。

序列定义:输入序列是二叉树的层序遍历,其从上到下、从左到右依次将节点值入队(包含空节点,但序列尾部空节点会被省略),非空节点为非000值,空节点以000值表示。

例111: image 表示为:

999

1 2 0 4 0 0 0 51\ 2\ 0\ 4\ 0\ 0\ 0\ 51 2 0 4 0 0 0 5

第一行为序列长度,第二行为层序遍历序列

例222: image 表示为:

666

1 5 2 3 0 61\ 5\ 2\ 3\ 0\ 61 5 2 3 0 6

注:给定的二叉树非空的合法序列,层序遍历序列长度<=500,−100<=<=500,-100<=<=500,−100<=数值<=100<=100<=100

输入描述

输入层序遍历序列(见题干说明)

输出描述

二叉树的直径

样例1

输入

9
1 2 0 3 4 0 0 0 5

输出

3

登录后即可使用 AI 分析。

模式
倒计时时长
:

最长 10 小时 59 分;应用后按此时长重新开始。

提示:点击提交记录在左侧题面区域查看详情
题库
AI分析设置
留空使用官方API Key,每天有次数限制(自定义API Key仅限会员和管理员使用,不限次数)
会员和管理员可切换模型;切到 Kimi/智谱/通义/豆包时需填写对应供应商 API Key
升级会员,可将运行与提交冷却时间缩短至 1 秒起

Status

  • Judging Queue
  • Service Status

Development

  • Open Source

Support

  • Help
  • Contact Us

About

  • About
  • Privacy
  • Terms of Service
  • Copyright Complaint
  1. Language
    1. English
    2. 한국어
    3. 简体中文
    4. 正體中文
  2. Legacy mode
  3. Theme
    1. Light
    2. Dark
  1. 京ICP备2025123107号-1
  2. Worker 0, 58ms
  3. Powered by Hydro v5.0.0-beta.18 Community
CLOSE


ScanQRCodePrompt

请使用微信扫描下方二维码完成注册

Forgot password or username?