数组4.0
时间限制:C/C++/Rust/Pascal 1秒,其他语言2秒
空间限制:C/C++/Rust/Pascal 256 M,其他语言512 M
64bit IO Format: %lld

题目描述

小红有一个长度为 n 的数组 a,下标从 1 开始。

如果两个数 a_i,a_j的绝对差值为 1,那么 i,j 之间存在一条无向边。

为了使得所有索引之间相互可达,小红至少需要手动再加多少条边。

输入描述:

每个测试文件均包含多组测试数。第一行输入一个整数 T(1\leq T\leq 1000),代表数据组数,每组测试数据描述如下:
对于每一组测试数据:

第一行一个整数 n(1\leq n\leq 2\times 10^5),表示数组长度。

第二行 n 个整数,第 i 个数为 a_i(1\leq a_i\leq 2\times 10^5),表示数组元素。

单个测试文件保证 \sum n\leq 2\times 10^5

输出描述:

输出共 T 行,每行一个整数,表示一个整数,表示至少需要手动再加多少条边才是使得图联通。
示例1

输入

复制
2
3
1 2 3
2
1 1

输出

复制
0
1