Cod sursa(job #1914530)

Utilizator miruna1224Floroiu Miruna miruna1224 Data 8 martie 2017 17:22:10
Problema Numarare triunghiuri Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.6 kb
#include <iostream>
#include<fstream>
#include<algorithm>

using namespace std;

ifstream in("nrtri.in");
ofstream out("nrtri.out");

int v[30001],n;
const int N=1<<20;

int caut(int x)
{
    int pas=1,r=0;
    while(pas!=N)
    {
        if(pas+r<=n && v[pas+r]<=x)
            r+=pas;
        pas*=2;
    }
        return r;
}

int main()
{
    int j,i,c=0,k;
    in>>n;
    for(i=1; i<=n; i++)
        in>>v[i];
    sort(v+1,v+n+1);
    for(i=1; i<n; i++)
        for(j=i+1; j<=n; j++)
        {
            k=caut(v[i]+v[j]);
            if(k!=0)
                c+=j-k;
        }
    out<<c;
    return 0;
}