Package for this problem was not updated by the problem writer or Codeforces administration after we’ve upgraded the judging servers. To adjust the time limit constraint, solution execution time will be multiplied by 2. For example, if your solution works for 400 ms on judging servers, then value 800 ms will be displayed and used to determine the verdict.

Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only ICPC mode for virtual contests.
If you've seen these problems, a virtual contest is not for you - solve these problems in the archive.
If you just want to solve some problem from a contest, a virtual contest is not for you - solve this problem in the archive.
Never use someone else's code, read the tutorials or communicate with other person during a virtual contest.

No tag edit access

H. The Great Marathon

time limit per test

4 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputOn the Berland Dependence Day it was decided to organize a great marathon. Berland consists of *n* cities, some of which are linked by two-way roads. Each road has a certain length. The cities are numbered from 1 to *n*. It is known that one can get from any city to any other one by the roads.

*n* runners take part in the competition, one from each city. But Berland runners are talkative by nature and that's why the juries took measures to avoid large crowds of marathon participants. The jury decided that every runner should start the marathon from their hometown. Before the start every sportsman will get a piece of paper containing the name of the city where the sportsman's finishing line is. The finish is chosen randomly for every sportsman but it can't coincide with the sportsman's starting point. Several sportsmen are allowed to finish in one and the same city. All the sportsmen start simultaneously and everyone runs the shortest route from the starting point to the finishing one. All the sportsmen run at one speed which equals to 1.

After the competition a follow-up table of the results will be composed where the sportsmen will be sorted according to the nondecrease of time they spent to cover the distance. The first *g* sportsmen in the table will get golden medals, the next *s* sportsmen will get silver medals and the rest will get bronze medals. Besides, if two or more sportsmen spend the same amount of time to cover the distance, they are sorted according to the number of the city where a sportsman started to run in the ascending order. That means no two sportsmen share one and the same place.

According to the rules of the competition the number of gold medals *g* must satisfy the inequation *g*_{1} ≤ *g* ≤ *g*_{2}, where *g*_{1} and *g*_{2} are values formed historically. In a similar way, the number of silver medals *s* must satisfy the inequation *s*_{1} ≤ *s* ≤ *s*_{2}, where *s*_{1} and *s*_{2} are also values formed historically.

At present, before the start of the competition, the destination points of every sportsman are unknown. However, the press demands details and that's why you are given the task of counting the number of the ways to distribute the medals. Two ways to distribute the medals are considered different if at least one sportsman could have received during those distributions different kinds of medals.

Input

The first input line contains given integers *n* and *m* (3 ≤ *n* ≤ 50, *n* - 1 ≤ *m* ≤ 1000), where *n* is the number of Berland towns and *m* is the number of roads.

Next in *m* lines road descriptions are given as groups of three integers *v*, *u*, *c*, which are the numbers of linked towns and its length (1 ≤ *v*, *u* ≤ *n*, *v* ≠ *u*, 1 ≤ *c* ≤ 1000). Every pair of cities have no more than one road between them.

The last line contains integers *g*_{1}, *g*_{2}, *s*_{1}, *s*_{2} (1 ≤ *g*_{1} ≤ *g*_{2}, 1 ≤ *s*_{1} ≤ *s*_{2}, *g*_{2} + *s*_{2} < *n*). The input data numbers, located on one line, are space-separated.

Output

Print the single number — the number of ways to distribute the medals. It is guaranteed that the number fits in the standard 64-bit signed data type.

Examples

Input

3 2

1 2 1

2 3 1

1 1 1 1

Output

3

Input

4 5

1 2 2

2 3 1

3 4 2

4 1 2

1 3 3

1 2 1 1

Output

19

Input

3 3

1 2 2

2 3 1

3 1 2

1 1 1 1

Output

4

Codeforces (c) Copyright 2010-2019 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Sep/24/2019 13:14:02 (f1).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|