Cod sursa(job #2215439)
Utilizator | Data | 22 iunie 2018 10:27:44 | |
---|---|---|---|
Problema | Cautare binara | Scor | 0 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 1.64 kb |
#include <fstream>
#include <algorithm>
using namespace std;
ifstream f("cautbin.in");
ofstream g("cautbin.out");
int n,v[100001],i,x,m,pr,p,u,ok1,poz,j,mm;
int main()
{
f>>n;
for (i=1;i<=n;i++)
{
f>>v[i];
}
f>>mm;
for (i=1;i<=mm;i++)
{
f>>pr>>x;
ok1=0;
if (pr==0)
{
p=1;
u=n;
while (p<=u)
{
m=(p+u)/2;
if (v[m]<x)
{
p=m+1;
}
else
if (v[m]==x)
{
ok1=1;
poz=m;
break;
}
else
{
u=m-1;
}
}
if (ok1==0)
{
g<<"-1"<<'\n';
}
else
{
for (j=poz;j<=n;j++)
{
if (v[j]!=x)
{
break;
}
}
j--;
g<<j<<'\n';
}
}
else
if (pr==2)
{
poz=lower_bound(v+1,v+n+1,x)-v;
if (v[poz]>x)
{
poz--;
}
g<<poz<<'\n';
}
else
{
poz=upper_bound(v+1,v+n+1,x)-v;
if (v[poz]>x)
{
poz--;
}
if (poz>n)
{
poz--;
}
g<<poz<<'\n';
}
}
return 0;
}