Cod sursa(job #2609385)

Utilizator stanbianca611Stan Bianca stanbianca611 Data 2 mai 2020 15:40:32
Problema Numarare triunghiuri Scor 0
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 1.02 kb
#include <iostream>
#include <fstream>
#include <algorithm>

using namespace std;
ifstream f ("nrtri.in");
ofstream g ("nrtri.out");
int v[805], n, rez=0;

int cautare_binara(int x, int st, int dr)
{
    if(st==dr)
    {
        if(v[st]>=x)
            return st;
        else return -1;
    }
    else if (dr-st==1)
    {
        if(v[st]>=x)
            return st;
        else if(v[dr]>=x)
            return dr;
        else return -1;
    }
    else if(st<dr)
    {
        int mij=(st+dr)/2;
        if(v[mij]>=x)
            return mij;
        else if (mij+1<=dr) cautare_binara(x, mij+1, dr);
    }
    else
    {
        return -1;
    }
}

int main()
{
    f>>n;
    for(int i=0; i<n; i++)
        f>>v[i];
    sort(v, v+n);
    for(int i=0; i<=n-3; i++)
    {
        for(int j=i+2; j<=n-1; j++)
        {
            int x=v[i];
            int y=v[j];
            if(cautare_binara(y-x, i+1, j-1)!=-1)
                rez++;
        }
    }
    g<<rez;
    return 0;
}