Pagini recente » Cod sursa (job #1548472) | Cod sursa (job #1917517) | Cod sursa (job #1863609) | Cod sursa (job #994832) | Cod sursa (job #2691007)
#include<cstdio>
int n,m,i,v[100001],x,y,s,l;
int main()
{
freopen("cautbin.in","r",stdin),freopen("cautbin.out","w",stdout),scanf("%d",&n);
for(i=1;i<=n;i++)
scanf("%d",v+i);
scanf("%d",&m);
for(l=1;l<=n;l<<=1);
while(m--)
{
scanf("%d%d",&x,&y);
if(x<2)
{
for(s=l,i=0;s;s>>=1)
if(i+s<=n&&v[i+s]<=y)
i+=s;
printf("%d\n",!x&&v[i]!=y?-1:i);
continue;
}
for(s=l,i=n;s;s>>=1)
if(i>s&&v[i-s]>=y)
i-=s;
printf("%d\n",i);
}
}