Cod sursa(job #1423785)

Utilizator george99Darie George george99 Data 22 aprilie 2015 18:17:38
Problema Cautare binara Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 1.05 kb
#include <fstream>
using namespace std;
ifstream f("cautbin.in");
ofstream g("cautbin.out");
int n,m,v[100010],i,j,mij,x,y;
void r0()
{
    i=1;j=n;
    while(i<=j)
        {
            mij=(i+j)/2;
            if(v[mij]<=y)i=mij+1;
                else j=mij-1;
        }
        mij=(i+j)/2;
        if(v[mij]>y)mij--;
        if(v[mij]==y) g<<mij<<"\n";
        else g<<"-1"<<'\n';
}
void r1()
{
    i=1;j=n;
    while(i<j)
        {
            mij=(i+j)/2;
            if(v[mij]<=y)i=mij+1;
                else j=mij;
        }
        mij=(i+j)/2;
        if(v[mij]>y)--mij;
        g<<mij<<"\n";

}
void r2()
{
    i=1;j=n;
    while(i<j)
        {
            mij=(i+j)/2;
            if(v[mij]<y)i=mij+1;
                else j=mij;
        }
        mij=(i+j)/2;
        if(v[mij]<y)++mij;
        g<<mij<<"\n";

}
int main()
{
    f>>n;for(i=1;i<=n;i++)f>>v[i];
    f>>m;
    while(m--)
    {
        f>>x>>y;
        if(x==0)r0();
        if(x==1)r1();
        if(x==2)r2();
    }
    return 0;
}