Class Solution
- java.lang.Object
-
- g1901_2000.s1928_minimum_cost_to_reach_destination_in_time.Solution
-
public class Solution extends Object
1928 - Minimum Cost to Reach Destination in Time.Hard
There is a country of
ncities numbered from0ton - 1where all the cities are connected by bi-directional roads. The roads are represented as a 2D integer arrayedgeswhereedges[i] = [xi, yi, timei]denotes a road between citiesxiandyithat takestimeiminutes to travel. There may be multiple roads of differing travel times connecting the same two cities, but no road connects a city to itself.Each time you pass through a city, you must pay a passing fee. This is represented as a 0-indexed integer array
passingFeesof lengthnwherepassingFees[j]is the amount of dollars you must pay when you pass through cityj.In the beginning, you are at city
0and want to reach cityn - 1inmaxTimeminutes or less. The cost of your journey is the summation of passing fees for each city that you passed through at some moment of your journey ( including the source and destination cities).Given
maxTime,edges, andpassingFees, return the minimum cost to complete your journey, or-1if you cannot complete it withinmaxTimeminutes.Example 1:

Input: maxTime = 30, edges = [[0,1,10],[1,2,10],[2,5,10],[0,3,1],[3,4,10],[4,5,15]], passingFees = [5,1,2,20,20,3]
Output: 11
Explanation: The path to take is 0 -> 1 -> 2 -> 5, which takes 30 minutes and has $11 worth of passing fees.
Example 2:

Input: maxTime = 29, edges = [[0,1,10],[1,2,10],[2,5,10],[0,3,1],[3,4,10],[4,5,15]], passingFees = [5,1,2,20,20,3]
Output: 48
Explanation: The path to take is 0 -> 3 -> 4 -> 5, which takes 26 minutes and has $48 worth of passing fees. You cannot take path 0 -> 1 -> 2 -> 5 since it would take too long.
Example 3:
Input: maxTime = 25, edges = [[0,1,10],[1,2,10],[2,5,10],[0,3,1],[3,4,10],[4,5,15]], passingFees = [5,1,2,20,20,3]
Output: -1
Explanation: There is no way to reach city 5 from city 0 within 25 minutes.
Constraints:
1 <= maxTime <= 1000n == passingFees.length2 <= n <= 1000n - 1 <= edges.length <= 10000 <= xi, yi <= n - 11 <= timei <= 10001 <= passingFees[j] <= 1000- The graph may contain multiple edges between two nodes.
- The graph does not contain self loops.
-
-
Constructor Summary
Constructors Constructor Description Solution()
-