codeforces#P1981E. Turtle and Intersected Segments
Turtle and Intersected Segments
Description
Turtle just received $n$ segments and a sequence $a_1, a_2, \ldots, a_n$. The $i$-th segment is $[l_i, r_i]$.
Turtle will create an undirected graph $G$. If segment $i$ and segment $j$ intersect, then Turtle will add an undirected edge between $i$ and $j$ with a weight of $|a_i - a_j|$, for every $i \ne j$.
Turtle wants you to calculate the sum of the weights of the edges of the minimum spanning tree of the graph $G$, or report that the graph $G$ has no spanning tree.
We say two segments $[l_1, r_1]$ and $[l_2, r_2]$ intersect if and only if $\max(l_1, l_2) \le \min(r_1, r_2)$.
Each test contains multiple test cases. The first line contains the number of test cases $t$ ($1 \le t \le 10^5$). The description of the test cases follows.
The first line of each test case contains a single integer $n$ ($2 \le n \le 5 \cdot 10^5$) — the number of segments.
The $i$-th of the following $n$ lines contains three integers $l_i, r_i, a_i$ ($1 \le l_i \le r_i \le 10^9, 1 \le a_i \le 10^9$) — the $i$-th segment and the $i$-th element of the sequence.
It is guaranteed that the sum of $n$ over all test cases does not exceed $5 \cdot 10^5$.
For each test case, output a single integer — the sum of the weights of the edges of the minimum spanning tree of the graph $G$. If the graph $G$ has no spanning tree, output $-1$.
Input
Each test contains multiple test cases. The first line contains the number of test cases $t$ ($1 \le t \le 10^5$). The description of the test cases follows.
The first line of each test case contains a single integer $n$ ($2 \le n \le 5 \cdot 10^5$) — the number of segments.
The $i$-th of the following $n$ lines contains three integers $l_i, r_i, a_i$ ($1 \le l_i \le r_i \le 10^9, 1 \le a_i \le 10^9$) — the $i$-th segment and the $i$-th element of the sequence.
It is guaranteed that the sum of $n$ over all test cases does not exceed $5 \cdot 10^5$.
Output
For each test case, output a single integer — the sum of the weights of the edges of the minimum spanning tree of the graph $G$. If the graph $G$ has no spanning tree, output $-1$.
4
5
1 7 3
2 4 6
3 5 5
6 7 9
3 4 4
5
2 7 3
1 3 6
4 5 5
6 7 9
1 1 4
4
1 4 3
1 2 1
3 4 5
1 4 4
3
1 3 1
2 3 3
4 5 8
9
13
4
-1
Note
In the first test case, the graph $G$ is as follows:
data:image/s3,"s3://crabby-images/5f44d/5f44d37afcae74a782c7a8aa405d4374ace860ba" alt=""
One of the minimum spanning trees of $G$ is as follows:
data:image/s3,"s3://crabby-images/c58f1/c58f1174f49496ec2e3043df03547936e97931ef" alt=""
The sum of the weights of the edges of the minimum spanning tree is $9$.
In the second test case, the graph $G$ is as follows:
data:image/s3,"s3://crabby-images/cbd35/cbd351dd6bfb7b937cecad7241dabd0ab85e9024" alt=""
$G$ is already a tree, and the sum of the weights of the tree is $13$.
In the third test case, the graph $G$ is as follows:
data:image/s3,"s3://crabby-images/a93cd/a93cd0dd51d76b9c90aa7d9409e265c697fded97" alt=""
In the fourth test case, the graph $G$ is as follows:
data:image/s3,"s3://crabby-images/1b565/1b5651d0991eb23ccb8c6c89b31bc6bef87f3d30" alt=""
It's easy to see that $G$ is not connected, so $G$ has no spanning tree.