Leetcode 2023-12-06 题目分享
2646. 最小化旅行的价格总和 [Hard] 题解
Leetcode 2646. 最小化旅行的价格总和
现有一棵无向、无根的树,树中有 n
个节点,按从
0
到 n - 1
编号。给你一个整数 n
和一个长度为 n - 1
的二维整数数组 edges
,其中
edges[i] = [ai, bi]
表示树中节点 ai
和
bi
之间存在一条边。
每个节点都关联一个价格。给你一个整数数组 price
,其中
price[i]
是第 i
个节点的价格。
给定路径的 价格总和 是该路径上所有节点的价格之和。
另给你一个二维整数数组 trips
,其中
trips[i] = [starti, endi]
表示您从节点 starti
开始第 i
次旅行,并通过任何你喜欢的路径前往节点
endi
。
在执行第一次旅行之前,你可以选择一些 非相邻节点 并将价格减半。
返回执行所有旅行的最小价格总和。
示例 1:
1 | 输入:n = 4, edges = [[0,1],[1,2],[1,3]], price = [2,2,10,6], trips = [[0,3],[2,1],[2,3]] |
示例 2:
1 | 输入:n = 2, edges = [[0,1]], price = [2,2], trips = [[0,0]] |
提示:
1 <= n <= 50
edges.length == n - 1
0 <= ai, bi <= n - 1
edges
表示一棵有效的树price.length == n
price[i]
是一个偶数1 <= price[i] <= 1000
1 <= trips.length <= 100
0 <= starti, endi <= n - 1
思路
- 首先肯定要根据访问的路径来统计每个节点最终会被访问多少次。
- 由于是一颗树,每次将起点当做根节点向下搜索即可。遇到终点就返回true,根据返回值来判断当前节点访问次数是否要++。
- 然后就是经典的01-DP问题:对于任何一个节点:
- 选择价格降低一半:那所有子节点都必须是原来价格
- 不选择:那那所有子节点可以减半,也可以不减半–取两者最小值
代码
1 | class Solution { |
复杂度分析
- 时间:O(n*t+n)=O(n*t)。n,t分别是节点数量和旅行次数。
- 空间:O(n)。
Comments
Comment plugin failed to load
Loading comment plugin