Cod sursa(job #881744)

Utilizator George515600Bejan George George515600 Data 18 februarie 2013 15:50:49
Problema Cautare binara Scor 60
Compilator c Status done
Runda Arhiva educationala Marime 1.53 kb
#include <stdio.h>
#include <stdlib.h>

int solve0 (int v[], int val, int hi)
{
    int lo, mid;
    lo = 1;
    while (lo <= hi)
    {
        mid = lo + (hi-lo)/2;
        if (v[mid] <= val) lo = mid + 1;
        else hi = mid - 1;
    }
    mid = lo + (hi-lo)/2;
    if (v[mid] > val) mid--;
    if (v[mid] == val) return mid;
    return -1;
}


int solve1 (int v[], int val, int hi)
{
int lo, mid;
    lo = 1;
    while (lo <= hi)
    {
        mid = lo + (hi-lo)/2;
        if (v[mid] <= val) lo = mid + 1;
        else hi = mid - 1;
    }
    mid = lo + (hi-lo)/2;
    if (v[mid] > val) mid--;
    return mid;
}
int solve2 (int v[], int val, int hi)
{
    int lo, mid;
    lo = 1;
    while (lo <= hi)
    {
        mid = lo + (hi-lo)/2;
        if (v[mid] < val) lo = mid + 1;
        else hi = mid - 1;
    }
    mid = lo + (hi-lo)/2;
    if (v[mid] < val) mid++;
    return mid;
}

int main()
{
    FILE *f;
    FILE *g;
    f = fopen("cautbin.in","r");
    g = fopen("cautbin.out","w");
    int n,i;
    int v[100010];
    fscanf(f,"%d",&n);

    for (i = 1; i <= n; i++)
        fscanf(f,"%d", &v[i]);

    int m,tip,val;
    fscanf(f,"%d", &m);
    while (m--)
    {
        fscanf(f,"%d %d", &tip, &val);
        if (tip == 0)
            fprintf(g,"%d\n", solve0(v, val, n));
        if (tip == 1)
            fprintf(g,"%d\n", solve1(v, val, n));
        if (tip == 2)
            fprintf(g,"%d\n", solve2(v, val, n));
    }

    close(f);
    close(g);

    return 0;

}