Rating changes for the last round are temporarily rolled back. They will be returned soon.
×

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

D. Delivery Bears

time limit per test

2 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputNiwel is a little golden bear. As everyone knows, bears live in forests, but Niwel got tired of seeing all the trees so he decided to move to the city.

In the city, Niwel took on a job managing bears to deliver goods. The city that he lives in can be represented as a directed graph with *n* nodes and *m* edges. Each edge has a weight capacity. A delivery consists of a bear carrying weights with their bear hands on a simple path from node 1 to node *n*. The total weight that travels across a particular edge must not exceed the weight capacity of that edge.

Niwel has exactly *x* bears. In the interest of fairness, no bear can rest, and the weight that each bear carries must be exactly the same. However, each bear may take different paths if they like.

Niwel would like to determine, what is the maximum amount of weight he can deliver (it's the sum of weights carried by bears). Find the maximum weight.

Input

The first line contains three integers *n*, *m* and *x* (2 ≤ *n* ≤ 50, 1 ≤ *m* ≤ 500, 1 ≤ *x* ≤ 100 000) — the number of nodes, the number of directed edges and the number of bears, respectively.

Each of the following *m* lines contains three integers *a*_{i}, *b*_{i} and *c*_{i} (1 ≤ *a*_{i}, *b*_{i} ≤ *n*, *a*_{i} ≠ *b*_{i}, 1 ≤ *c*_{i} ≤ 1 000 000). This represents a directed edge from node *a*_{i} to *b*_{i} with weight capacity *c*_{i}. There are no self loops and no multiple edges from one city to the other city. More formally, for each *i* and *j* that *i* ≠ *j* it's guaranteed that *a*_{i} ≠ *a*_{j} or *b*_{i} ≠ *b*_{j}. It is also guaranteed that there is at least one path from node 1 to node *n*.

Output

Print one real value on a single line — the maximum amount of weight Niwel can deliver if he uses exactly *x* bears. Your answer will be considered correct if its absolute or relative error does not exceed 10^{ - 6}.

Namely: let's assume that your answer is *a*, and the answer of the jury is *b*. The checker program will consider your answer correct if .

Examples

Input

4 4 3

1 2 2

2 4 1

1 3 1

3 4 2

Output

1.5000000000

Input

5 11 23

1 2 3

2 3 4

3 4 5

4 5 6

1 3 4

2 4 5

3 5 6

1 4 2

2 5 3

1 5 2

3 2 30

Output

10.2222222222

Note

In the first sample, Niwel has three bears. Two bears can choose the path , while one bear can choose the path . Even though the bear that goes on the path can carry one unit of weight, in the interest of fairness, he is restricted to carry 0.5 units of weight. Thus, the total weight is 1.5 units overall. Note that even though Niwel can deliver more weight with just 2 bears, he must use exactly 3 bears on this day.

Codeforces (c) Copyright 2010-2020 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Apr/01/2020 11:20:53 (f3).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|