Cod sursa(job #2194004)

Utilizator richard26Francu Richard richard26 Data 11 aprilie 2018 22:08:26
Problema Cautare binara Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 1.09 kb
#include <fstream>

using namespace std;

ifstream fin("cautbin.in");
ofstream fout("cautbin.out");

int a[100005];

int main(){
  int n;
  fin >> n;
  for(int i=1;i<=n;++i){
    fin >> a[i];
  }
  int m;
  fin >> m;
  for(int i=1;i<=m;++i){
    int op, x, st=1, dr=n, rasp, mij;
    fin >> op >> x;
    rasp=-1;
    if(op == 0) {
      while(st<=dr){
        mij = (st+dr)/2;
        if(a[mij]==x){
          rasp=mij;
          st=mij+1;
        }
        else if(a[mij]<x){
          st=mij+1;
        }
        else if(a[mij]>x){
          dr=mij-1;
        }
      }
    } else if(op == 1){
      while(st<=dr){
        mij = (st+dr)/2;
        if(a[mij]<=x){
          rasp = mij;
          st = mij+1;
        }
        else if(a[mij]>x){
          dr = mij- 1;
        }
      }
    } else if(op == 2){
      while(st<=dr){
        mij = (st+dr)/2;
        if(a[mij]>=x){
          rasp = mij;
          dr = mij - 1;
        }
        else if(a[mij]<x){
          st = mij + 1;
        }
      }
    }
    fout << rasp << '\n';
  }

  return 0;
}