codeforces#P1737D. Ela and the Wiring Wizard

Ela and the Wiring Wizard

Description

Ela needs to send a large package from machine $1$ to machine $n$ through a network of machines. Currently, with the network condition, she complains that the network is too slow and the package can't arrive in time. Luckily, a Wiring Wizard offered her a helping hand.

The network can be represented as an undirected connected graph with $n$ nodes, each node representing a machine. $m$ wires are used to connect them. Wire $i$ is used to connect machines $u_i$ and $v_i$, and has a weight $w_i$. The aforementioned large package, if going through wire $i$, will move from machine $u_i$ to machine $v_i$ (or vice versa) in exactly $w_i$ microseconds. The Wiring Wizard can use his spell an arbitrary number of times. For each spell, he will choose the wire of index $i$, connecting machine $u_i$ and $v_i$, and rewire it following these steps:

  • Choose one machine that is connected by this wire. Without loss of generality, let's choose $v_i$.
  • Choose a machine that is currently connecting to $v_i$ (including $u_i$), call it $t_i$. Disconnect the wire indexed $i$ from $v_i$, then using it to connect $u_i$ and $t_i$.

The rewiring of wire $i$ will takes $w_i$ microseconds, and the weight of the wire will not change after this operation. After a rewiring, a machine might have some wire connect it with itself. Also, the Wiring Wizard has warned Ela that rewiring might cause temporary disconnections between some machines, but Ela just ignores it anyway. Her mission is to send the large package from machine $1$ to machine $n$ as fast as possible. Note that the Wizard can use his spell on a wire zero, one, or many times. To make sure the network works seamlessly while transferring the large package, once the package starts transferring from machine $1$, the Wiring Wizard cannot use his spell to move wires around anymore.

Ela wonders, with the help of the Wiring Wizard, what is the least amount of time needed to transfer the large package from machine $1$ to $n$.

Each test contains multiple test cases. The first line contains the number of test cases $t$ ($1 \le t \le 100$). The description of the test cases follows.

The first line contains $n$ and $m$ ($2 \le n \le 500$, $n - 1 \le m \le 250 000$), the number of nodes and number of wires, respectively.

For the next $m$ lines, $i$-th line will contains $u_i$, $v_i$ and $w_i$ ($1 \le u_i, v_i \le n$, $1 \le w_i \le 10^9$) - the indices 2 machines that are connected by the $i$-th edge and the weight of it.

It is guaranteed that the sum of $n$ over all test cases does not exceed $500$ and the sum of $m$ over all test cases does not exceed $250 000$. The graph in each test case is guaranteed to be connected, no self-loops, but it can contain multiple edges.

For each test case, output one integer denotes the least amount of time needed to transfer the large package from machine $1$ to $n$.

Input

Each test contains multiple test cases. The first line contains the number of test cases $t$ ($1 \le t \le 100$). The description of the test cases follows.

The first line contains $n$ and $m$ ($2 \le n \le 500$, $n - 1 \le m \le 250 000$), the number of nodes and number of wires, respectively.

For the next $m$ lines, $i$-th line will contains $u_i$, $v_i$ and $w_i$ ($1 \le u_i, v_i \le n$, $1 \le w_i \le 10^9$) - the indices 2 machines that are connected by the $i$-th edge and the weight of it.

It is guaranteed that the sum of $n$ over all test cases does not exceed $500$ and the sum of $m$ over all test cases does not exceed $250 000$. The graph in each test case is guaranteed to be connected, no self-loops, but it can contain multiple edges.

Output

For each test case, output one integer denotes the least amount of time needed to transfer the large package from machine $1$ to $n$.

3
8 9
1 2 3
6 4 5
3 5 6
6 1 3
7 4 4
3 8 4
2 3 3
7 8 5
4 5 2
4 5
1 2 1
2 4 1
3 4 1
3 1 1
1 3 2
8 8
4 6 92
7 1 65
6 5 43
6 7 96
4 3 74
4 8 54
7 4 99
2 5 22
9
2
154

Note

Here is the graph in the first test case in the sample input:

Ela can ask the Wiring Wizard to use his spell on wire with the index of $7$, which is connecting machines $2$ and $3$. Then, since the machine $8$ is connected to machine $3$, the Wiring Wizard can disconnect wire $7$ from machine $3$ and connect it to machine $8$ in $3$ microseconds (weight of wire $3$).

After that, the package can be sent from machine $1$ to machine $8$ in $6$ microseconds. Therefore, the answer is $3 + 6 = 9$ microseconds.

Here is the graph in the third test case in the sample input: