5921:最大化一张图中的路径价值
This commit is contained in:
parent
2fa5b0edd4
commit
6c5fbad345
156
src/main/java/leetcode/editor/cn/MaximumPathQualityOfAGraph.java
Normal file
156
src/main/java/leetcode/editor/cn/MaximumPathQualityOfAGraph.java
Normal file
@ -0,0 +1,156 @@
|
||||
//给你一张 无向 图,图中有 n 个节点,节点编号从 0 到 n - 1 (都包括)。同时给你一个下标从 0 开始的整数数组 values ,其中
|
||||
//values[i] 是第 i 个节点的 价值 。同时给你一个下标从 0 开始的二维整数数组 edges ,其中 edges[j] = [uj, vj, timej] 表示
|
||||
//节点 uj 和 vj 之间有一条需要 timej 秒才能通过的无向边。最后,给你一个整数 maxTime 。
|
||||
//
|
||||
// 合法路径 指的是图中任意一条从节点 0 开始,最终回到节点 0 ,且花费的总时间 不超过 maxTime 秒的一条路径。你可以访问一个节点任意次。一条合法
|
||||
//路径的 价值 定义为路径中 不同节点 的价值 之和 (每个节点的价值 至多 算入价值总和中一次)。
|
||||
//
|
||||
// 请你返回一条合法路径的 最大 价值。
|
||||
//
|
||||
// 注意:每个节点 至多 有 四条 边与之相连。
|
||||
//
|
||||
//
|
||||
//
|
||||
// 示例 1:
|
||||
//
|
||||
//
|
||||
//
|
||||
//
|
||||
//输入:values = [0,32,10,43], edges = [[0,1,10],[1,2,15],[0,3,10]], maxTime = 49
|
||||
//输出:75
|
||||
//解释:
|
||||
//一条可能的路径为:0 -> 1 -> 0 -> 3 -> 0 。总花费时间为 10 + 10 + 10 + 10 = 40 <= 49 。
|
||||
//访问过的节点为 0 ,1 和 3 ,最大路径价值为 0 + 32 + 43 = 75 。
|
||||
//
|
||||
//
|
||||
// 示例 2:
|
||||
//
|
||||
//
|
||||
//
|
||||
//
|
||||
//输入:values = [5,10,15,20], edges = [[0,1,10],[1,2,10],[0,3,10]], maxTime = 30
|
||||
//输出:25
|
||||
//解释:
|
||||
//一条可能的路径为:0 -> 3 -> 0 。总花费时间为 10 + 10 = 20 <= 30 。
|
||||
//访问过的节点为 0 和 3 ,最大路径价值为 5 + 20 = 25 。
|
||||
//
|
||||
//
|
||||
// 示例 3:
|
||||
//
|
||||
//
|
||||
//
|
||||
//
|
||||
//输入:values = [1,2,3,4], edges = [[0,1,10],[1,2,11],[2,3,12],[1,3,13]], maxTime
|
||||
//= 50
|
||||
//输出:7
|
||||
//解释:
|
||||
//一条可能的路径为:0 -> 1 -> 3 -> 1 -> 0 。总花费时间为 10 + 13 + 13 + 10 = 46 <= 50 。
|
||||
//访问过的节点为 0 ,1 和 3 ,最大路径价值为 1 + 2 + 4 = 7 。
|
||||
//
|
||||
// 示例 4:
|
||||
//
|
||||
//
|
||||
//
|
||||
//
|
||||
//输入:values = [0,1,2], edges = [[1,2,10]], maxTime = 10
|
||||
//输出:0
|
||||
//解释:
|
||||
//唯一一条路径为 0 。总花费时间为 0 。
|
||||
//唯一访问过的节点为 0 ,最大路径价值为 0 。
|
||||
//
|
||||
//
|
||||
//
|
||||
//
|
||||
// 提示:
|
||||
//
|
||||
//
|
||||
// n == values.length
|
||||
// 1 <= n <= 1000
|
||||
// 0 <= values[i] <= 10⁸
|
||||
// 0 <= edges.length <= 2000
|
||||
// edges[j].length == 3
|
||||
// 0 <= uj < vj <= n - 1
|
||||
// 10 <= timej, maxTime <= 100
|
||||
// [uj, vj] 所有节点对 互不相同 。
|
||||
// 每个节点 至多有四条 边。
|
||||
// 图可能不连通。
|
||||
//
|
||||
// 👍 1 👎 0
|
||||
|
||||
package leetcode.editor.cn;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
//5921:最大化一张图中的路径价值
|
||||
class MaximumPathQualityOfAGraph {
|
||||
public static void main(String[] args) {
|
||||
//测试代码
|
||||
Solution solution = new MaximumPathQualityOfAGraph().new Solution();
|
||||
}
|
||||
|
||||
//力扣代码
|
||||
//leetcode submit region begin(Prohibit modification and deletion)
|
||||
class Solution {
|
||||
public int maximalPathQuality(int[] values, int[][] edges, int maxTime) {
|
||||
Map<Integer, List<int[]>> map = new HashMap<>();
|
||||
for (int i = 0; i < values.length; i++) {
|
||||
map.put(i, new ArrayList<>());
|
||||
}
|
||||
for (int[] edge : edges) {
|
||||
List<int[]> list = map.get(edge[0]);
|
||||
list.add(new int[]{edge[1], edge[2]});
|
||||
map.put(edge[0], list);
|
||||
list = map.get(edge[1]);
|
||||
list.add(new int[]{edge[0], edge[2]});
|
||||
map.put(edge[1], list);
|
||||
}
|
||||
max = values[0];
|
||||
int[] use = new int[values.length];
|
||||
use[0] = 1;
|
||||
pathDfs(map, values[0], use, maxTime, 0, 0, values);
|
||||
return max;
|
||||
}
|
||||
|
||||
int max;
|
||||
|
||||
private void pathDfs(Map<Integer, List<int[]>> map, int value, int[] use, int maxTime, int time, int index, int[] values) {
|
||||
List<int[]> list = map.get(index);
|
||||
for (int[] arr : list) {
|
||||
time += arr[1];
|
||||
if (time > maxTime) {
|
||||
time -= arr[1];
|
||||
continue;
|
||||
}
|
||||
if (arr[0] > 0 && use[arr[0]] == 2) {
|
||||
continue;
|
||||
}
|
||||
if (use[arr[0]] == 0) {
|
||||
value += values[arr[0]];
|
||||
}
|
||||
use[arr[0]]++;
|
||||
if (arr[0] == 0) {
|
||||
max = Math.max(value, max);
|
||||
}
|
||||
if (time == maxTime) {
|
||||
time -= arr[1];
|
||||
if (use[arr[0]] == 1) {
|
||||
value -= values[arr[0]];
|
||||
}
|
||||
use[arr[0]]--;
|
||||
continue;
|
||||
}
|
||||
pathDfs(map, value, use, maxTime, time, arr[0], values);
|
||||
time -= arr[1];
|
||||
if (use[arr[0]] == 1) {
|
||||
value -= values[arr[0]];
|
||||
}
|
||||
use[arr[0]]--;
|
||||
}
|
||||
}
|
||||
}
|
||||
//leetcode submit region end(Prohibit modification and deletion)
|
||||
|
||||
}
|
@ -0,0 +1,74 @@
|
||||
<p>给你一张 <strong>无向</strong> 图,图中有 <code>n</code> 个节点,节点编号从 <code>0</code> 到 <code>n - 1</code> (<strong>都包括</strong>)。同时给你一个下标从 <strong>0</strong> 开始的整数数组 <code>values</code> ,其中 <code>values[i]</code> 是第 <code>i</code> 个节点的 <strong>价值</strong> 。同时给你一个下标从 <strong>0</strong> 开始的二维整数数组 <code>edges</code> ,其中 <code>edges[j] = [u<sub>j</sub>, v<sub>j</sub>, time<sub>j</sub>]</code> 表示节点 <code>u<sub>j</sub></code> 和 <code>v<sub>j</sub></code> 之间有一条需要 <code>time<sub>j</sub></code> 秒才能通过的无向边。最后,给你一个整数 <code>maxTime</code> 。</p>
|
||||
|
||||
<p><strong>合法路径</strong> 指的是图中任意一条从节点 <code>0</code> 开始,最终回到节点 <code>0</code> ,且花费的总时间 <strong>不超过</strong> <code>maxTime</code> 秒的一条路径。你可以访问一个节点任意次。一条合法路径的 <b>价值</b> 定义为路径中 <strong>不同节点</strong> 的价值 <strong>之和</strong> (每个节点的价值 <strong>至多</strong> 算入价值总和中一次)。</p>
|
||||
|
||||
<p>请你返回一条合法路径的 <strong>最大</strong> 价值。</p>
|
||||
|
||||
<p><strong>注意:</strong>每个节点 <strong>至多</strong> 有 <strong>四条</strong> 边与之相连。</p>
|
||||
|
||||
<p> </p>
|
||||
|
||||
<p><strong>示例 1:</strong></p>
|
||||
|
||||
<p><img alt="" src="https://assets.leetcode.com/uploads/2021/10/19/ex1drawio.png" style="width: 269px; height: 170px;" /></p>
|
||||
|
||||
<pre>
|
||||
<b>输入:</b>values = [0,32,10,43], edges = [[0,1,10],[1,2,15],[0,3,10]], maxTime = 49
|
||||
<b>输出:</b>75
|
||||
<strong>解释:</strong>
|
||||
一条可能的路径为:0 -> 1 -> 0 -> 3 -> 0 。总花费时间为 10 + 10 + 10 + 10 = 40 <= 49 。
|
||||
访问过的节点为 0 ,1 和 3 ,最大路径价值为 0 + 32 + 43 = 75 。
|
||||
</pre>
|
||||
|
||||
<p><strong>示例 2:</strong></p>
|
||||
|
||||
<p><img alt="" src="https://assets.leetcode.com/uploads/2021/10/19/ex2drawio.png" style="width: 269px; height: 170px;" /></p>
|
||||
|
||||
<pre>
|
||||
<b>输入:</b>values = [5,10,15,20], edges = [[0,1,10],[1,2,10],[0,3,10]], maxTime = 30
|
||||
<b>输出:</b>25
|
||||
<strong>解释:</strong>
|
||||
一条可能的路径为:0 -> 3 -> 0 。总花费时间为 10 + 10 = 20 <= 30 。
|
||||
访问过的节点为 0 和 3 ,最大路径价值为 5 + 20 = 25 。
|
||||
</pre>
|
||||
|
||||
<p><strong>示例 3:</strong></p>
|
||||
|
||||
<p><img alt="" src="https://assets.leetcode.com/uploads/2021/10/19/ex31drawio.png" style="width: 236px; height: 170px;" /></p>
|
||||
|
||||
<pre>
|
||||
<b>输入:</b>values = [1,2,3,4], edges = [[0,1,10],[1,2,11],[2,3,12],[1,3,13]], maxTime = 50
|
||||
<b>输出:</b>7
|
||||
<strong>解释:</strong>
|
||||
一条可能的路径为:0 -> 1 -> 3 -> 1 -> 0 。总花费时间为 10 + 13 + 13 + 10 = 46 <= 50 。
|
||||
访问过的节点为 0 ,1 和 3 ,最大路径价值为 1 + 2 + 4 = 7 。</pre>
|
||||
|
||||
<p><strong>示例 4:</strong></p>
|
||||
|
||||
<p><strong><img alt="" src="https://assets.leetcode.com/uploads/2021/10/21/ex4drawio.png" style="width: 270px; height: 71px;" /></strong></p>
|
||||
|
||||
<pre>
|
||||
<b>输入:</b>values = [0,1,2], edges = [[1,2,10]], maxTime = 10
|
||||
<b>输出:</b>0
|
||||
<b>解释:</b>
|
||||
唯一一条路径为 0 。总花费时间为 0 。
|
||||
唯一访问过的节点为 0 ,最大路径价值为 0 。
|
||||
</pre>
|
||||
|
||||
<p> </p>
|
||||
|
||||
<p><strong>提示:</strong></p>
|
||||
|
||||
<ul>
|
||||
<li><code>n == values.length</code></li>
|
||||
<li><code>1 <= n <= 1000</code></li>
|
||||
<li><code>0 <= values[i] <= 10<sup>8</sup></code></li>
|
||||
<li><code>0 <= edges.length <= 2000</code></li>
|
||||
<li><code>edges[j].length == 3 </code></li>
|
||||
<li><code>0 <= u<sub>j </sub>< v<sub>j</sub> <= n - 1</code></li>
|
||||
<li><code>10 <= time<sub>j</sub>, maxTime <= 100</code></li>
|
||||
<li><code>[u<sub>j</sub>, v<sub>j</sub>]</code> 所有节点对 <strong>互不相同</strong> 。</li>
|
||||
<li>每个节点 <strong>至多有四条 </strong>边。</li>
|
||||
<li>图可能不连通。</li>
|
||||
</ul>
|
||||
<div><li>👍 1</li><li>👎 0</li></div>
|
Loading…
Reference in New Issue
Block a user