Cod sursa(job #1512038)

Utilizator lonca.sorinLonca Sorin lonca.sorin Data 27 octombrie 2015 17:12:35
Problema Numarare triunghiuri Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.65 kb
#include <iostream>
#include <fstream>
#include <algorithm>

using namespace std;

int a[803],n,s,dr,st,mijloc,rez,i,j;

int main()
{
    ifstream f("nrtri.in");
    ofstream g("nrtri.out");
    f>>n;
    for (i=1;i<=n;i++)
        f>>a[i];
    sort (a+1,a+n+1);
    for (i=1;i<=n-2;i++)
        for (j=i+1;j<=n-1;j++){
            s=a[j]+a[i];
            st=j;
            dr=n+1;
            while (dr-st!=1)
            {
                mijloc=(st+dr)/2;
                if (a[mijloc]<=s)
                    st=mijloc;
                else dr=mijloc;
            }
            rez=rez+st-j;
        }
    g<<rez;
    return 0;
}