Pagini recente » Cod sursa (job #1008710) | Cod sursa (job #565173) | Cod sursa (job #733773) | Cod sursa (job #59910) | Cod sursa (job #921959)
Cod sursa(job #921959)
#include <cstdio>
#define NMAX 100001
int V[NMAX];
int n,step,m,log;
int main(){
int cod,i,x;
freopen("cautbin.in","r",stdin);
freopen("cautbin.out","w",stdout);
scanf("%d",&n);
for(register int i=1;i<=n;++i)
scanf("%d",&V[i]);
scanf("%d",&m);
while(m){
scanf("%d%d",&cod,&x);
if(cod < 2){
for(log = 1;log<=n;log<<=1)
for(i=0,step=log;step;step>>=1)
if(i+step <=n && V[i+step] <=x)
i+=step;
if(!cod && V[i]!=x)
printf("-1\n");
else printf("%d\n",i);
}
else{
for(log = 1;log<=n;log<<=1)
for(i=n,step=log;step;step>>=1)
if(i-step > 0 && V[i-step] >=x)
i-=step;
printf("%d\n",i);
}
--m;
}
return 0;
}