Cod sursa(job #2326270)

Utilizator AndreiDeltaBalanici Andrei Daniel AndreiDelta Data 23 ianuarie 2019 13:35:20
Problema Numarare triunghiuri Scor 0
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.69 kb
#include <bits/stdc++.h>
#define Dim 804
using namespace std;
ifstream f("nrtri.in");
ofstream g("nrtri.out");
int N,V[Dim],maxim,ans;

int CB(int x)
{
    int st=1,dr=N;
    while(st<=dr)
    {
        int mij=(st+dr)/2;
        if(V[mij]==x)
        {
            return mij;
            break;
        }else
        if(x<V[mij]) dr=mij-1;
        else
        if(x>V[mij]) st=mij+1;
    }
    return st;
}

int main()
{
  f>>N;
  for(int i=1;i<=N;i++) f>>V[i];
  sort(V+1,V+N+1);
  for(int i=1;i<=N;i++)
    for(int j=i+1;j<=N;j++)
  {
      maxim=max(V[j]-V[i],V[i]-V[j]);
      int nr=CB(V[i]+V[j])-CB(maxim)+1;
      ans+=nr;
  }
  g<<ans;
    return 0;
}