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 表示该位置没有员工;再给出两名员工工号 u、v。
  • 要求:找到两人级别最低的共同主管,并返回该主管子树中的员工总数(不含主管本人)。

核心做法:

  1. 数组建树 + 反向索引

P3844.第1题-组织架构管理系统

    1000ms Tried: 719 Accepted: 198 Difficulty: 4 所属公司 : 华为
    算法与标签>树

题目内容

你正在开发一个企业的组织架构管理系统,公司的组织架构被 简化表示为一棵二叉树。树的每个节点代表一个员工,树的层级越低则级别越高,高级别作为主管,管辖其子树涉及的所有员工。

每个人有一个唯一的工号,工号以整数值表示,范围是 [0,109][0,10^9][0,109] 。

此管理系统需要提供一个统计能力,对任意两名员工,找到他们级别最低的共同主管,返回当前主管管辖的人员个数。

注意:

  • 如果两名员工本身存在上下级关系,共同主管为级别较高的员工。

  • 员工总数 <=105<= 10^5<=105。

  • 待检索员工的工号一定在给定的二叉树中,且两位员工工号不同。

输入描述

  • 第一行为一个整数,表示输入的节点个数。

  • 第二行为一行数字,由空格分割,每个数字表示一颗满一叉树各层从左到右的节点。值为员工工号,−1-1−1 代表该节点不存在。

例 111 222 333 444 −1-1−1 555 −1-1−1 −1-1−1 666 可转化为下图的一又树,

  • 第三行为两个数字,用空格分割,表示待检索的两名员工工号,例如:555 111 。

输出描述

输出级别最低的共同主管管辖的人员总个数(不包括自身)。

样例1

输入

12
2 3 5 1 7 6 8 -1 -1 0 4 -1
0 3

输出

4

说明

000 和 333 存在上下级关系,共同主管为 333 ,管辖总人数为 444 。

样例2

输入

9
1 2 3 4 -1 5 -1 -1 6
5 4

输出

5

说明

555 和 444 的共同主管为节点 111 ,管辖总人数为 555 。

登录后即可使用 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 3, 145ms
  3. Powered by Hydro v5.0.0-beta.18 Community
CLOSE


ScanQRCodePrompt

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

Forgot password or username?