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

C. Strange Radiation

time limit per test

3 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard output*n* people are standing on a coordinate axis in points with positive integer coordinates strictly less than 10^{6}. For each person we know in which direction (left or right) he is facing, and his maximum speed.

You can put a bomb in some point with non-negative integer coordinate, and blow it up. At this moment all people will start running with their maximum speed in the direction they are facing. Also, two strange rays will start propagating from the bomb with speed *s*: one to the right, and one to the left. Of course, the speed *s* is strictly greater than people's maximum speed.

The rays are strange because if at any moment the position and the direction of movement of some ray and some person coincide, then the speed of the person immediately increases by the speed of the ray.

You need to place the bomb is such a point that the minimum time moment in which there is a person that has run through point 0, and there is a person that has run through point 10^{6}, is as small as possible. In other words, find the minimum time moment *t* such that there is a point you can place the bomb to so that at time moment *t* some person has run through 0, and some person has run through point 10^{6}.

Input

The first line contains two integers *n* and *s* (2 ≤ *n* ≤ 10^{5}, 2 ≤ *s* ≤ 10^{6}) — the number of people and the rays' speed.

The next *n* lines contain the description of people. The *i*-th of these lines contains three integers *x*_{i}, *v*_{i} and *t*_{i} (0 < *x*_{i} < 10^{6}, 1 ≤ *v*_{i} < *s*, 1 ≤ *t*_{i} ≤ 2) — the coordinate of the *i*-th person on the line, his maximum speed and the direction he will run to (1 is to the left, i.e. in the direction of coordinate decrease, 2 is to the right, i.e. in the direction of coordinate increase), respectively.

It is guaranteed that the points 0 and 10^{6} will be reached independently of the bomb's position.

Output

Print the minimum time needed for both points 0 and 10^{6} to be reached.

Your answer is considered correct if its absolute or relative error doesn't exceed 10^{ - 6}. Namely, if your answer is *a*, and the jury's answer is *b*, then your answer is accepted, if .

Examples

Input

2 999

400000 1 2

500000 1 1

Output

500000.000000000000000000000000000000

Input

2 1000

400000 500 1

600000 500 2

Output

400.000000000000000000000000000000

Note

In the first example, it is optimal to place the bomb at a point with a coordinate of 400000. Then at time 0, the speed of the first person becomes 1000 and he reaches the point 10^{6} at the time 600. The bomb will not affect on the second person, and he will reach the 0 point at the time 500000.

In the second example, it is optimal to place the bomb at the point 500000. The rays will catch up with both people at the time 200. At this time moment, the first is at the point with a coordinate of 300000, and the second is at the point with a coordinate of 700000. Their speed will become 1500 and at the time 400 they will simultaneously run through points 0 and 10^{6}.

Codeforces (c) Copyright 2010-2020 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Sep/21/2020 10:52:10 (i1).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|