A lot of big storms.
Warm air and cold air don't mix very nicely – because whenever they do, storms tend to follow.
Your job, as a Turbulent Location Estimator, is to track their movement.
Air currents in your area can be mapped into
nodes and
air channels.
Initially, there is one warm air body at node
and one cold air body at node
.
Each channel connects two distinct nodes
and
with a traverse time of
.
All channels are bidirectional and have a confined path. No two nodes will have more than one channel connecting them.
Air bodies naturally expand.
So, they may intersect at nodes, or even on channels!
Wherever this occurs, the present air bodies cannot pass through each other.
However, if this occurs on a node that connects to other unoccupied channels, then the present air bodies can continue to spread to those channels simultaneously alongside each other.
You have been given
queries, each asking for
: the exact time when a storm occurs at a particular location.
It is possible to reach any node from any other node.
Have you got what it takes for the job?
Constraints
data:image/s3,"s3://crabby-images/5a0a6/5a0a6a49cdf79d7aa2189b9273c02939c042fc84" alt="1 \le X, Y, A_i, B_i \le N \le 100\,000"
data:image/s3,"s3://crabby-images/7717c/7717c8012024dfb2ecbbcb4e67b39c47b49fa1de" alt="N-1 \le M \le \min\left(\frac{N(N-1)}{2}, 200\,000\right)"
data:image/s3,"s3://crabby-images/76500/76500d41c314ef129a3e34d6e8ca95a499e79748" alt="1 \le C_i \le 5\,000"
data:image/s3,"s3://crabby-images/7b56b/7b56b3ddfe8ea9164fad0ce3fe5e9dea22e03745" alt="1 \le Q \le 300\,000"
Note: It is possible to have
.
Subtask |
Percentage |
Additional Constraints |
data:image/s3,"s3://crabby-images/3d4b5/3d4b52d888877de9126ceaa67d0af714515dd7aa" alt="1" |
data:image/s3,"s3://crabby-images/bcddd/bcddd90c8d321e6a4ef48677572982c27de6abc2" alt="10" |
, data:image/s3,"s3://crabby-images/afa2a/afa2ada9f227baae8e1204e2bc7fedac2cac159e" alt="C_i = 1" |
data:image/s3,"s3://crabby-images/e1a9f/e1a9f81e41cb37d754abee2e7a5a722e7d93867a" alt="2" |
data:image/s3,"s3://crabby-images/e7951/e79514f32a2e915014b5d0b16a5bcb1b9bd19d83" alt="20" |
, data:image/s3,"s3://crabby-images/40b03/40b035e13f3e0f4abd5097dfa93b5eae7b841275" alt="X = Y" |
data:image/s3,"s3://crabby-images/15f76/15f7623d4228bf050ed3d62d48d62380466287c3" alt="3" |
data:image/s3,"s3://crabby-images/858ac/858acf5d8fc32818efca33ed39100f8ba7eba325" alt="30" |
, data:image/s3,"s3://crabby-images/0d1e2/0d1e2e15d641d601fdadefa79f1982d9a7d52cf2" alt="F_i = 1" |
data:image/s3,"s3://crabby-images/77cd7/77cd7ecd1c599f428af98df0e8f3e50651d07844" alt="4" |
data:image/s3,"s3://crabby-images/e9afb/e9afb92962d57a6c7ff8fedcefd8cbf3791be88e" alt="40" |
No additional constraints. |
Input Specification
The first line contains four spaced integers:
,
,
, and
.
The following
lines each contain three spaced integers:
,
, and
.
The next line contains integer
.
The following
lines each contain two spaced integers:
and
.
If
, then
is the number of a node
.
If
, then
is the number of a channel
.
Channel numbers appear in order in the input, starting at
.
Output Specification
For each query, output
on its own line.
Time starts at
.
If a storm does not exist at that location, output -1
.
Your answer will be judged as correct if it is within an absolute error of
.
Sample Input
Copy
7 7 1 3
1 2 6
1 5 7
2 3 6
2 6 5
3 4 1
4 5 3
5 7 8
5
1 2
1 5
1 6
2 2
2 4
Sample Output
Copy
6
-1
11
5.5
6
Explanation
The warm air body starts at node
while the cool air body starts at node
.
They both spread to reach node
at the same time, causing a storm there at
.
Then, they both simultaneously spread alongside each other to node
at
.
Note that storms occur along the entire path of channel
, so we take the earliest incidence time as
(rounded from a time negligibly greater than
).
Meanwhile, the cool air body reaches node
first, spreading to node
and
.
It essentially blocks off the warm air body's path to node
.
Thus, both bodies of air directly collide on channel
at
.
Comments