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 video solution AI分析

思路:递归建树 + 模拟

  1. 构建平衡二叉搜索树: 1.根据题意,将输入的节点值进行升序排序。 2.使用递归的方法,选择中间元素作为当前根节点,递归构建左右子树,保证平衡。

  2. 收集叶子节点: 遍历整棵树,找到所有叶子节点(左右子树均为空的节点),并将它们的值存入列表。

P2273.第1题-满足查询范围的平衡树数据之和

    1000ms Tried: 544 Accepted: 128 Difficulty: 5 所属公司 : 华为
    算法与标签>递归

题目内容

数据库索引技术使用平衡树从树根到叶子节点的高度基本一致的特点,将数据保存到叶子节点,从而可以实

现从树根查找到叶子遍历的节点数基本一致,使查询速度更加稳定。

给定一个数组,经过升序排列后,构造平衡二叉树,查询平衡二叉树满足条件的叶子节点的数据之和。

平衡二叉树的定义和约束如下:

a)a)a)每个节点的左右子树的高度差的绝对值不超过111

b)b)b)左右子树也是平衡二叉树

c)c) c)递增排序后构造的平衡二叉树是唯一的

输入描述

第一行:一个数组,第一个数据是节点数,范围是[1,50001,50001,5000],后面跟的是树的节点值,范围是[1,200001,200001,20000]。

第二行:平衡树叶子节点值的查询范围,包含333个数,第一个数是个数,第二个数和第三个数分别是最小值和最大值。

输出描述

满足查询范围的叶节点的数据之和,如果找不到满足查询条件的叶节点,则输出叶节点的最大值,其他情况返回−1-1−1。

样例1

输入

6 7 17 35 56 65 66
2 56 67

输出

122

说明

叶节点的值分别是17 56 6617\ 56\ 6617 56 66,满足>=56>=56>=56且<=67<=67<=67的是56 6656\ 6656 66,所以求和是122122122。

​                35

​            /        \

​          7           65

​            \       /      \

​            17     56      66

样例2

输入

2 1 2100
2 1 1		

输出

2100

说明

叶子节点的值210021002100,不满足查询范围111,所以输出叶子节点最大值210021002100。

​    1

​      \

​       2100

开通会员即可查看完整视频题解: 1.题目讲解 2.思路分析 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 2, 56ms
  3. Powered by Hydro v5.0.0-beta.18 Community
CLOSE


ScanQRCodePrompt

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

Forgot password or username?