Cod sursa(job #1822273)

Utilizator Daniel1999Daniel-Nicolae Paraschiv Daniel1999 Data 4 decembrie 2016 17:26:11
Problema Cautare binara Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.6 kb
#include <bits/stdc++.h>

using namespace std;
int a[100005],x,y,m,n;
int main()
{
    ifstream fin("cautbin.in");
    ofstream fout("cautbin.out");
    fin>>n;
    for(int i=1;i<=n;i++)
        fin>>a[i];
    fin>>m;
    for(int i=1;i<=m;i++)
       {
        fin>>x>>y;
    if(x==0)
    {
        x=upper_bound(a+1,a+n+1,y) -(a+1);
         if (a[x]==y && x!=1) fout<<y<<endl;
         else fout<<-1<<endl;
    }
    else
        if(x==1)
    {
        fout<<upper_bound(a+1,a+n+1,x) - (a+1) <<endl;

    }
    else fout<<lower_bound(a+1,a+n+1,x) -a<<endl;

       }
    return 0;
}