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

Kimi K2.6 思考 LeetCode 3241. 标记所有节点需要的时间 Python3实现

LeetCode 3241. 标记所有节点需要的时间 — Python3 实现

题目概述

给定一棵无向树,节点编号 `0` 到 `n-1`。每个节点 `i` 被标记的规则:
- 奇数节点:相邻节点在时刻 `x-1` 被标记,则 `i` 在时刻 `x` 被标记(耗时 1)
- 偶数节点:相邻节点在时刻 `x-2` 被标记,则 `i` 在时刻 `x` 被标记(耗时 2)

求以每个节点为起点时,标记所有节点所需的最长时间。

核心思路

将问题转化为树形 DP + 换根(Re-rooting):

1. 边权定义:从节点 `u` 到相邻节点 `v` 的"传播时间"取决于 `v` 的奇偶性
- `v` 为奇数:边权 = 1
- `v` 为偶数:边权 = 2

2. 两次 DFS:
- 第一次 DFS:计算每个节点子树内的最大深度和次大深度
- 第二次 DFS(换根):计算每个节点往父节点方向的最长路径,得到最终答案

Python3 实现

```python
class Solution:
def timeTaken(self, edges: List[List[int]]) -> List[int]:
n = len(edges) + 1
g = [[] for _ in range(n)]
for x, y in edges:
g[x].append(y)
g[y].append(x)

# node[x] = (mx1, mx2, my)
# mx1: 子树 x 的最大深度, mx2: 次大深度, my: 最大深度对应的子节点
node = [[0, 0, 0] for _ in range(n)]
ans = [0] * n

def dfs(x: int, fa: int) -> int:
mx1 = mx2 = my = 0
for y in g[x]:
if y == fa:
continue
# 从 x 到 y 的边权: y 是偶数则 2, 奇数则 1
depth = dfs(y, x) + 2 - y % 2
if mx1 < depth:
mx2 = mx1
mx1 = depth
my = y
elif mx2 < depth:
mx2 = depth
node[x] = [mx1, mx2, my]
return mx1

def reroot(x: int, fa: int, from_: int):
ans[x] = max(from_, node[x][0])
for y in g[x]:
if y != fa:
# up1: 从 y 往上走到父节点 x 再继续往上
up1 = from_ + 2 - x % 2
# up2: 从 y 往上走到 x, 然后在 x 的其他子树中拐弯
up2 = (node[x][1] if y == node[x][2] else node[x][0]) + 2 - x % 2
reroot(y, x, max(up1, up2))

dfs(0, -1)
reroot(0, -1, 0)
return ans
```

关键逻辑说明

变量 含义
`node[x][0]` 以 `x` 为根的子树中,往子树方向的最大深度
`node[x][1]` 以 `x` 为根的子树中,往子树方向的次大深度
`node[x][2]` 最大深度对应的子节点编号
`from_` 从当前节点往父节点方向走的最长路径长度
`up1` 从子节点 `y` 往上经过 `x` 继续往上的路径
`up2` 从子节点 `y` 往上到 `x`,然后在 `x` 的其他子树中拐弯的路径

复杂度分析

- 时间复杂度:O(n),每个节点访问常数次
- 空间复杂度:O(n),递归栈和存储数组

示例验证

输入:`edges = [[0,1],[0,2]]`

- `i=0`:节点 1(奇数,耗时 1)→ `t=1`,节点 2(偶数,耗时 2)→ `t=2`,答案 = `2`
- `i=1`:节点 0(偶数,耗时 2)→ `t=2`,节点 2 需经过 0(偶数,耗时 2)→ `t=4`,答案 = `4`
- `i=2`:节点 0(偶数,耗时 2)→ `t=2`,节点 1(奇数,耗时 1)→ `t=3`,答案 = `3`

输出:`[2, 4, 3]` ✓

http://www.gsyq.cn/news/1521808.html

相关文章:

  • Ferret模型原理与多模态指代理解实战
  • MathPrompter:结构化提示+分步验证的数学推理工程方法论
  • 告别破解版!手把手教你用WinLicense 3.1.3.0为你的软件穿上‘防弹衣’
  • 终极解密:3步解锁你的加密音频宝藏,让音乐自由流动
  • 不止于替代:深度评测GD60914 vs MLX90614,在600℃高温、防尘与远距离探测上的实际表现
  • MLflow本地实验追踪实战:30分钟构建可追溯可复现的机器学习工作流
  • 2026图片去背景抠图保姆级教程:专业电脑软件+免费在线网站+手机APP全攻略
  • HAL库真的‘笨重’吗?用CubeMX和LL库在STM32G0上做平衡开发
  • 从单片机到PLC:手把手教你根据项目需求选对迪文串口屏(DGUS vs 指令集避坑指南)
  • Discord机器人定时任务实现详解
  • 多维聚合不是GROUP BY:数据变形术与语义校准实战
  • MLflow生产级落地:PostgreSQL+MinIO构建可审计模型追踪系统
  • 告别隐私合规烦恼:用uniappx插件Ba-IdCode-U一站式搞定Android设备ID获取(附厂商支持清单)
  • 上岸必看!【中药学】真实模考纯净版(卷号:06121219_09)
  • CANN单边通信库hixl在PD分离推理中的实战应用:昇腾NPU大模型Prefill-Decode分离部署与零拷贝通信优化深度指南
  • 给STM32新手的建议:别急着学HAL库,先用标准库搞懂GPIO和TIM(附CubeMX对比)
  • 南京九源安全科技矿车自动灭火系统—以智能主动防御,重塑矿山车辆安全与经济效益
  • 用Python处理气象数据:从NetCDF文件到南京周边温度垂直廓线图(附完整代码)
  • 别再手动点来点去了!用Windows批处理玩转Hex2bin:从校验和到字节填充的进阶配置指南
  • 如何构建高效持续集成系统:WSABuilds自动化构建实战指南
  • 从跑酷到搬砖:聊聊波士顿动力Atlas机器人背后的液压驱动与电机驱动之争
  • RLHF实操路线图:从偏好数据到PPO微调的9小时落地指南
  • 从图像处理到机器学习:手把手教你用MATLAB reshape函数搞定数据预处理
  • 暗黑破坏神2存档编辑器:5分钟快速上手,打造你的专属游戏体验
  • AI内容分发引擎怎么搭_用CSDN_AI数字营销跑通完整工作流
  • 从WPF老手到Qt新手:我踩过的那些C++内存管理和信号槽的“坑”
  • Pika 1.0免费开放后,我花了一下午实测这5个核心功能(附避坑指南)
  • 智慧树自动学习助手:告别手动刷课的3步智能方案
  • 前端开发与社交媒体装点神器:解锁HTML/CSS和微信昵称中的迷你上标下标玩法
  • 抖音视频下载终极指南:3分钟掌握无水印批量下载技巧