#include <stdio.h>
#include <algorithm>
using namespace std ;
struct node
{
int l ;
int r ;
int id ;
};
node a[200100] ;
int pre[200100] ;
int col[200100] ;
int c[200100] ;
int ans[200100] ;
int last[1000100] ;
int n;
int lowbit(int x)
{
return x&(-x) ;
}
void update(int x , int p)
{
while(x <= n)
{
c[x] += p ;
x += lowbit(x) ;
}
}
int getsum(int x)
{
int sum = 0 ;
while(x)
{
sum += c[x] ;
x -= lowbit(x) ;
}
return sum ;
}
int cmp(node asdf, node b)
{
return asdf.r < b.r;
}
int main()
{
scanf("%d" , &n) ;
for(int i = 1 ; i <= n ; i++)
{
scanf("%d" , &col[i]) ;
pre[i] = last[col[i]] ;
last[col[i]] = i ;
}
int m ;
scanf("%d" , &m) ;
for(int i = 1 ; i <= m ;i++)
{
scanf("%d%d" , &a[i].l , &a[i].r) ;
a[i].id = i ;
}
sort(a + 1 , a + 1 + m , cmp) ;
int now = 0 ;
for(int i = 1 ; i <= m ; i++)
{
while(now < a[i].r)
{
now ++ ;
update(pre[now] + 1 , 1) ;
if(now != n){update(now + 1 ,-1) ;}
}
ans[a[i].id] = getsum(a[i].l) ;
}
for(int i = 1 ; i <= m ; i++)
{
printf("%d\n" , ans[i]) ;
}
}
BZOJ 1878 [SDOI2009]HH的项链 离线+树状数组
原文地址:http://blog.csdn.net/wzq_qwq/article/details/45535279