Pagini recente » Cod sursa (job #1048022) | Cod sursa (job #2902901) | Cod sursa (job #1042321) | Cod sursa (job #309158) | Cod sursa (job #1256634)
#include <fstream>
#include <algorithm>
using namespace std;
ifstream fin("cautbin.in");
ofstream fout("cautbin.out");
int a[100010],n,m,i,j,x,c,lo,hi,mi;
int main()
{
fin>>n;
for(i=1;i<=n;i++)fin>>a[i];
fin>>m;
for(;m;m--)
{
fin>>c>>x;
//i=(int)(lower_bound(a+1,a+n+1,x)-a);
//j=(int)(upper_bound(a+1,a+n+1,x)-a);
if(c<=1)
{
for(lo=0,hi=n+1;hi-lo>1;)
{
mi=(lo+hi)/2;
if(a[mi]<=x)lo=mi;
else hi=mi;
}
if(c==0&&a[lo]!=x)fout<<-1<<'\n';
else fout<<lo<<'\n';
continue;
//if(i==j)fout<<-1<<'\n';
//else fout<<j-1<<'\n';
}
for(lo=0,hi=n+1;hi-lo>1;)
{
mi=(lo+hi)/2;
if(a[mi]<x)lo=mi;
else hi=mi;
}
fout<<hi<<'\n';
}
return 0;
}