FUKU11J - Round Trip
English | Vietnamese |
Jim is planning to visit one of his best friends in a town in the mountain area. First, he leaves his hometown and goes to the destination town. This is called the go phase. Then, he comes back to his hometown. This is called the return phase. You are expected to write a program to find the minimum total cost of this trip, which is the sum of the costs of the go phase and the return phase.
There is a network of towns including these two towns. Every road in this network is one-way, i.e., can only be used towards the specified direction. Each road requires a certain cost to travel.
In addition to the cost of roads, it is necessary to pay a specified fee to go through each town on the way. However, since this is the visa fee for the town, it is not necessary to pay the fee on the second or later visit to the same town.
The altitude (height) of each town is given. On the go phase, the use of descending roads is inhibited. That is, when going from town a to b, the altitude of ashould not be greater than that of b. On the return phase, the use of ascending roads is inhibited in a similar manner. If the altitudes of a and b are equal, the road from a to b can be used on both phases.
Input
The input consists of multiple datasets, each in the following format.
n m
d2 e2
d3 e3
.
.
.
dn-1 en-1
a1 b1 c1
a2 b2 c2
.
.
.
am bm cm
Every input item in a dataset is a non-negative integer. Input items in a line are separated by a space.
n is the number of towns in the network. m is the number of (one-way) roads. You can assume the inequalities 2 ≤ n ≤ 50 and 0 ≤ m ≤ n(n−1) hold. Towns are numbered from 1 to n, inclusive. The town 1 is Jim's hometown, and the town n is the destination town.
di is the visa fee of the town i, and ei is its altitude. You can assume 1 ≤ di ≤ 1000 and 1≤ei ≤ 999 for 2≤i≤n−1. The towns 1 and n do not impose visa fee. The altitude of the town 1 is 0, and that of the town n is 1000. Multiple towns may have the same altitude, but you can assume that there are no more than 10 towns with the same altitude.
The j-th road is from the town aj to bj with the cost cj (1 ≤ j ≤ m). You can assume 1 ≤ aj ≤ n, 1 ≤ bj ≤ n, and 1 ≤ cj ≤ 1000. You can directly go from aj to bj, but not from bj to aj unless a road from bj to aj is separately given. There are no two roads connecting the same pair of towns towards the same direction, that is, for any i and j such that i ≠ j, ai ≠ aj or bi ≠ bj. There are no roads connecting a town to itself, that is, for any j, aj≠ bj.
The last dataset is followed by a line containing two zeros (separated by a space).
Output
For each dataset in the input, a line containing the minimum total cost, including the visa fees, of the trip should be output. If such a trip is not possible, output “-1”.
Example
Input: 3 6 3 1 1 2 1 2 3 1 3 2 1 2 1 1 1 3 4 3 1 4 3 6 5 1 1 2 1 2 3 1 3 2 1 2 1 1 1 3 4 3 1 4 4 5 3 1 3 1 1 2 5 2 3 5 3 4 5 4 2 5 3 1 5 2 1 2 1 1 0 0 Output: 7 8 36 -1
Added by: | Race with time |
Date: | 2012-07-18 |
Time limit: | 0.100s |
Source limit: | 50000B |
Memory limit: | 1536MB |
Cluster: | Cube (Intel G860) |
Languages: | All except: ASM64 |
Resource: | ACM ICPC Fukuoka 2011 |