apps_325


Submit solution

Points: 3
Time limit: 30.0s
Memory limit: 250M

Problem type
Allowed languages
Python

There is a directed graph with N vertices numbered 1 to N and M edges. The i-th edge is directed from Vertex A_i to Vertex B_i, and there are C_i coins placed along that edge. Additionally, there is a button on Vertex N. We will play a game on this graph. You start the game on Vertex 1 with zero coins, and head for Vertex N by traversing the edges while collecting coins. It takes one minute to traverse an edge, and you can collect the coins placed along the edge each time you traverse it. As usual in games, even if you traverse an edge once and collect the coins, the same number of coins will reappear next time you traverse that edge, which you can collect again. When you reach Vertex N, you can end the game by pressing the button. (You can also choose to leave Vertex N without pressing the button and continue traveling.) However, when you end the game, you will be asked to pay T \times P coins, where T is the number of minutes elapsed since the start of the game. If you have less than T \times P coins, you will have to pay all of your coins instead. Your score will be the number of coins you have after this payment. Determine if there exists a maximum value of the score that can be obtained. If the answer is yes, find that maximum value.

-----Constraints-----

  • 2 \leq N \leq 2500
  • 1 \leq M \leq 5000
  • 1 \leq A_i, B_i \leq N
  • 1 \leq C_i \leq 10^5
  • 0 \leq P \leq 10^5
  • All values in input are integers.
  • Vertex N can be reached from Vertex 1.

-----Input----- Input is given from Standard Input in the following format: N M P A_1 B_1 C_1 : A_M B_M C_M

-----Output----- If there exists a maximum value of the score that can be obtained, print that maximum value; otherwise, print -1.

-----Sample Input----- 3 3 10 1 2 20 2 3 30 1 3 45

-----Sample Output----- 35

There are two ways to travel from Vertex 1 to Vertex 3:

  • Vertex 1 \rightarrow 2 \rightarrow 3: You collect 20 + 30 = 50 coins on the way. After two minutes from the start of the game, you press the button, pay 2 \times 10 = 20 coins, and you have 50 - 20 = 30 coins left.
  • Vertex 1 \rightarrow 2: You collect 45 coins on the way. After one minute from the start of the game, you press the button, pay 1 \times 10 = 10 coins, and you have 45 - 10 = 35 coins left. Thus, the maximum score that can be obtained is 35.

Comments

There are no comments at the moment.