比赛 |
20160407 |
评测结果 |
AAAAAAAAAA |
题目名称 |
HH的项链 |
最终得分 |
100 |
用户昵称 |
/k |
运行时间 |
2.158 s |
代码语言 |
C++ |
内存使用 |
7.56 MiB |
提交时间 |
2016-04-07 11:34:07 |
显示代码纯文本
#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
#define gl(a) (a&((-a)))
struct u
{
int z;
int y;
int id;
int zz;
}c[200000+10];
int a[50000+10],x[1000000+10],s[50000+10];
int m,n;
bool g(const u & a,const u & b)
{
return a.y<b.y;
}
void gj(int a,int c)
{
while(a<=n)
{
s[a]+=c;
a+=gl(a);
}
return;
}
int gs(int a)
{
int uu=0;
while(a>0)
{
uu+=s[a];
a-=gl(a);
}
return uu;
}
bool gg(const u & a,const u & b)
{
return a.id < b.id;
}
int main()
{
freopen("diff.in", "r", stdin);
freopen("diff.out", "w", stdout);
scanf("%d",&n);
for(int i=1;i<=n;i++)
scanf("%d",&a[i]);
scanf("%d",&m);
for(int i=1;i<=m;i++)
{
scanf("%d%d",&c[i].z,&c[i].y);
c[i].id=i;
}
sort(c+1,c+m+1,g);
int w=1;
for(int i=1;i<=n;i++)
{
if(x[a[i]]!=0)
gj(x[a[i]],-1);
gj(i,1);
x[a[i]]=i;
while(c[w].y==i)
{
c[w].zz=gs(c[w].y)-gs(c[w].z-1);
++w;
}
}
sort(c+1,c+1+m,gg);
for(int i=1;i<=m;i++)
printf("%d\n",c[i].zz);
}