Pagini recente » Cod sursa (job #1114112) | Cod sursa (job #1501940) | Cod sursa (job #2506945) | Cod sursa (job #1874345) | Cod sursa (job #2669362)
#include <fstream>
using namespace std;
ifstream fin("cautbin.in");
ofstream fout("cautbin.out");
#define nmax 100005
int n, m, st, dr, mij, poz, cer, x;
int v[nmax];
void cautare0(int x){
poz=-1;
st=1; dr=n;
while (st<=dr){
mij=(st+dr)/2;
if (v[mij]==x)
poz=mij;
if (v[mij]<=x)
st = mij+1;
else
dr = mij-1;
}
}
void cautare1(int x){
poz=-1;
st=1; dr=n;
while (st<=dr){
mij=(st+dr)/2;
if (v[mij]<=x){
st = mij+1;
poz = mij;
}
else
dr = mij-1;
}
}
void cautare2(int x){
poz=-1;
st=1; dr=n;
while (st<=dr){
mij=(st+dr)/2;
if (v[mij]>=x){
dr = mij-1;
poz = mij;
}
else
st = mij+1;
}
}
int main()
{
int i;
fin>>n;
for(i=1;i<=n;i++)
fin>>v[i];
fin>>m;
for (int i=1;i<=m;i++){
fin>>cer>>x;
if (cer==0)
cautare0(x);
if (cer==1)
cautare1(x);
if (cer==2)
cautare2(x);
fout<<poz<<endl;
}
return 0;
}