Cod sursa(job #3343758)

Utilizator neo05Memet EDen neo05 Data 28 februarie 2026 13:36:05
Problema Cautare binara Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.78 kb
#include<bits/stdc++.h>
using namespace std;
ifstream fin ("cautbin.in");
ofstream fout ("cautbin.out");
long long int v[1000001],m,n,x,y;
int main(){
    fin>>n;//cout<<n;
    for(int i=1; i<=n; ++i){
        fin>>v[i];
    }
    sort(v+1,v+n+1);
    fin>>m;
    for(int i=1; i<=m; ++i){
        fin>>x>>y;
        if(x==0){
            long long int* val2= upper_bound(v+1,v+n+1,y);
            auto val = *lower_bound(v+1,v+n+1,y);
            if(val==y)
                fout<<val2-v-1<<"\n";
            else
                fout<<-1<<"\n";
        }
        if(x==1){
            long long int* val2= upper_bound(v+1,v+n+1,y);
            fout<<val2-v<<"\n";
        }
        if(x==2){
            long long int* val= lower_bound(v+1,v+n+1,y);
            fout<<val-v<<"\n";
        }
    }
}