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 维护两个量:

  • down[u]down[u]down[u]:从 uuu 向下走,到达其子树内某个红点的最大距离;若子树内不存在红点,设为负无穷(实现时用常数 −INF-\text{INF}−INF 代表,例如 −109-10^9−109)。
  • ans[u]ans[u]ans[u]:以 uuu 为根的子树内红点直径的答案。

P3748.第3题-红点直径

    1000ms Tried: 44 Accepted: 16 Difficulty: 6 所属公司 : 科大讯飞
    算法与标签>树

题目内容

给定一棵以节点111 为根的树,树上共有nnn 个节点,其中某些节点被标记为“红点”。

定义某点 uuu的红点直径为:在uuu 的子树中,任取两个红点之间的最大距离(路径上经过的边数)。

如果子树中的红点数<2<2<2 ,则红点直径为 000。

请计算每个节点的红点直径。

输入描述

第一行输入整数n(1≤n≤2×105)n(1≤n≤2×10^5)n(1≤n≤2×105) ,表示树的节点数。

第二行输入nnn个整数 ,其中c1,c2,...cnc_1,c_2,...c_nc1​,c2​,...cn​ ,其中ci∈0,1c_i∈0,1ci​∈0,1表示红点,000表示非红点。

接下来n−1n-1n−1 行,每行输入两个整数u,vu,vu,v ,表示树上的一条无向边。

输出描述

输出一行nnn 个整数,第iii 个数表示以节点iii 为根的子树的红点直径。

样例1

输入

5
0 1 0 1 1
1 2
1 3
1 4
4 5

输出

3 0 0 1 0

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


ScanQRCodePrompt

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

Forgot password or username?