Cod sursa(job #2240453)

Utilizator gabimoiseMoise Gabriel gabimoise Data 13 septembrie 2018 14:41:58
Problema Numarare triunghiuri Scor 70
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.93 kb
#include <iostream>
#include <cstdio>
#include <algorithm>

using namespace std;

long long rasp;
long i,j,q,v[1000],n,st,dr,mij;

int main()
{
    freopen("nrtri.in","r",stdin);
    freopen("nrtri.out","w",stdout);
    scanf("%ld",&n);
    for (i=1;i<=n;i++) scanf("%ld",&v[i]);
    sort(v+1,v+n+1);
    rasp=0;
    for (i=1;i<=n-1;i++)
        for (j=i+1;j<=n;j++)
    {
        st=1; dr=n;
        while (st<dr)
        {
            mij=(st+dr)/2;
            if (v[mij]>v[i]+v[j]) dr=mij-1;
            else if (v[j]>v[i]+v[mij]) st=mij+1;
            else break;
        }
        q=st;
        for (q=st;q<=n;q++)
            if ((v[i]+v[j]>=v[q]) && (v[i]+v[q]>=v[j]) && (v[j]+v[q]>=v[i]) && (i!=q) && (j!=q))
            {
                rasp++;
                //printf("%ld %ld %ld\n",v[i],v[j],v[q]);
            }
    }
    //printf("%lld\n",rasp);
    printf("%lld\n",rasp/3);
    return 0;
}