Shortest Path with Mandatory Waypoint
You are given a weighted graph with n nodes labeled 0 through n - 1. Each edge is represented as [u, v, w], meaning there is an edge between nodes u and v with non-negative distance w.
Compute two values:
- the length of the shortest path from
starttotarget - the length of the shortest path from
starttotargetthat must pass throughwaypoint
If a required path does not exist, use -1 for that entry.
Complete the function shortestPathWithWaypoint in the editor below.
shortestPathWithWaypoint has the following parameters:
int n: the number of nodesint[][] edges: undirected weighted edges[u, v, w]int start: the starting nodeint target: the destination nodeint waypoint: the node that the constrained path must visit
Returns
int[]: a length-2 array [bestDistance, bestDistanceViaWaypoint].
1Example 1
The shortest path from 0 to 4 is 0 -> 1 -> 2 -> 4 with total cost 6. That path already passes through the mandatory waypoint 1, so both answers are 6.
2Example 2
The unconstrained shortest path is 0 -> 1 -> 3 with cost 2. There is no path from 2 to 3, so no valid route can pass through the waypoint.
Constraints
Limits and guarantees your solution can rely on.
1 <= n <= 2 * 10^50 <= edges.length <= 3 * 10^50 <= w <= 10^9- All edge weights are non-negative.
- If no path exists for a requested scenario, return
-1for that entry.