/*4056:【GESP2403八级】接竹竿
flag 数组 存储每个元素出现的位置,nxt[i]=j;存储每个位置 后面第一次出现 与a【i】相等的位置
//其中 a【i]==a[j] :记录i的下一个位置 ,flag 存储每个值的位置
下一次 具有下一次,相当于的链表了,倒序 处理
for(int i=n;i>=1;i--) 建立 上面的位置关系
用map 记录 每次查询的 结果,如果重复查询 了,直接输出
map<pair<int,int>,int> mp;// mp[{l,r}]=cnt;
每次查询的时候,寻找队首在后面的
*/
#include<bits/stdc++.h>
using namespace std;
const int N=15000+5;
int nxt[N];//每个元素下次出现的位置
int flag[N];// 每个元素出现的位置
int a[N],n;
typedef pair<int,int> pii;
int main()
{
int T;
cin>>T;
while(T--)
{
map<pii,int> mp; //记录 结果
mp.clear();
memset(flag,0,sizeof flag);
memset(nxt,0,sizeof nxt);
cin>>n;
for(int i=1;i<=n;i++) cin>>a[i];
for(int i=n;i>=1;i--)
{
int x=a[i];
nxt[i]=flag[x]; //第i 个位置,后面第一次 出现的位置
flag[x]=i; //记录每个元素的位置
}
//查询 m次
int m;
cin>>m;
for(int i=1;i<=m;i++)
{
int L,R;
cin>>L>>R;
int cnt=0;
if(mp.count({L,R})>0)
{
printf("%d\n",mp[{L,R}]);
continue;
}
else //需要 查询 定位,是否需要删掉,默认结果为0
{
for(int j=L;j<=R;j++)
{
if(nxt[j]>=L&&nxt[j]<=R) //跳到可以消掉的地方,然后再往后面走一个
{
j=nxt[j];
}
else //不可以消掉,计数+1,然后寻找下一位
{
cnt++;
}
}
mp[{L,R}]=cnt;
//输出本次的结果
printf("%d\n",cnt);
}
}
}
return 0;
}