Pagini recente » Cod sursa (job #3341390) | Monitorul de evaluare | Cod sursa (job #3311722) | Cod sursa (job #2237310) | Cod sursa (job #3357382)
#include <iostream>
#include <fstream>
#include <algorithm>
using namespace std;
ifstream fin("nrtri.in");
ofstream fout("nrtri.out");
int n;
int v[801];
int cautare(int i, int j)
{
int st=j+1;
int dr=n-1;
int poz=j;
while(st<=dr)
{
int mij=(st+dr)/2;
if(v[i]+v[j]>=v[mij])
{
poz=mij;
st=mij+1;
}
else
dr=mij-1;
}
return poz;
}
int main()
{
fin >> n;
for(int i=0; i<n; i++)
fin >> v[i];
sort(v, v + n);
int cnt=0;
for(int i=0; i<n-2; i++)
{
for(int j=i+1; j<n-1; j++)
{
cnt+=cautare(i, j)-j;
}
}
fout << cnt;
return 0;
}