Pagini recente » Cod sursa (job #175508) | Cod sursa (job #1157525) | Cod sursa (job #1045490) | Cod sursa (job #619624) | Cod sursa (job #3141752)
#include <iostream>
#include <fstream>
using namespace std;
ifstream fin("cautbin.in");
ofstream fout("cautbin.out");
int n , m , v[100005];
int main()
{
fin>>n;
for(int i=1 ; i<=n ; i++)
fin>>v[i];
fin>>m;
for(int i=1 ; i<=m ; i++){
int cer , val;
fin>>cer>>val;
if(cer == 0){
int poz=0 , l=1 , r=n;
int mij;
while(l<=r){
mij=l+(r-l)/2;
if(val == v[mij]){
poz=mij;
l=mij+1;
}
else if(val < v[mij]){
l=mij+1;
}
else if(val > v[mij]){
r=mij-1;
}
}
if(poz!=0){
fout<<poz<<'\n';
}
else{
fout<<-1<<'\n';
}
}
else if(cer == 1){
int poz=0 , l=1 , r=n;
int mij;
while(l<=r){
mij=l+(r-l)/2;
if(val >= v[mij]){
poz=mij;
l=mij+1;
}
else if(val < v[mij]){
r=mij-1;
}
}
fout<<poz<<'\n';
}
else if(cer == 2){
int poz=0 , l=1 , r=n;
int mij;
while(l<=r){
mij=l+(r-l)/2;
if(val <= v[mij]){
poz=mij;
r=mij-1;
}
else if(val > v[mij]){
l=mij+1;
}
}
fout<<poz<<'\n';
}
}
return 0;
}