Cod sursa(job #721611)

Utilizator alexalbu95Albu Alexandru alexalbu95 Data 23 martie 2012 21:08:08
Problema Cautare binara Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.78 kb
#include <cstdio>
#include <algorithm>

using namespace std;

const int maxn=100100;

int n, a[maxn], i, q, x, y, k;

int main()
{
    freopen("cautbin.in", "r", stdin);
    freopen("cautbin.out", "w", stdout);

    scanf("%d", &n);
    for(i=1; i<=n; ++i) scanf("%d", a+i);

    for(scanf("%d", &q); q; --q)
    {
        scanf("%d %d", &y, &x);

        if(y==0)
        {
            k= upper_bound(a+1, a+n+1, x) - a - 1;
            if(a[k]==x) printf("%d\n", k);
            else printf("-1\n");
        }
        else if(y==1)
        {
            k= lower_bound(a+1, a+n+1, x+1) - a - 1;
            printf("%d\n", k);
        }
        else
        {
            k= upper_bound(a+1, a+n+1, x-1) - a;
            printf("%d\n", k);
        }
    }
}