Cod sursa(job #1360319)

Utilizator span7aRazvan span7a Data 25 februarie 2015 13:47:48
Problema Numarare triunghiuri Scor 55
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.75 kb
#include<fstream>
#include<algorithm>
using namespace std;
ifstream f("nrtri.in");
ofstream g("nrtri.out");
int n,a[801];
void citire()
{
    int i;
    f>>n;
    for(i=1;i<=n;i++)
        f>>a[i];
    sort(a+1,a+n+1);
}
int cauta(int inc,int sf,int k)
{
    int m;
    while(inc<=sf)
    {
        m=(inc+sf)/2;
        if(k<a[m])
            sf=m-1;
        else
            if(k==a[m])
                return m;
            else
                inc=m+1;
    }
    return sf;
}
void solve()
{
    int i,j,sol=0,poz;
    for(i=1;i<=n;i++)
        for(j=i+1;j<=n;j++)
        {
            poz=cauta(j,n,a[i]+a[j]);
            sol+=poz-j;

        }
    g<<sol<<'\n';
}
int main(){

    citire();
    solve();
return 0;
}