Pagini recente » Cod sursa (job #321474) | Cod sursa (job #344643) | Cod sursa (job #2101071) | Cod sursa (job #15272) | Cod sursa (job #2480710)
#include <iostream>
#include <fstream>
#include <algorithm>
using namespace std;
ifstream fin("nrtri.in");
ofstream fout("nrtri.out");
/*
int main()
{
int n,xi,yi,xf,yf;
fin>>n;
fin>>xi>>yi>>xf>>yf;
xf=max(xf,xi)-min(xf,xi);
yf=max(yf,yi)-min(yf,yi);
int maxa=0,maxr=0,a[n],r[n];
{
char c;
for(int i=0;i<n;i++)
{
fin>>c;
if(c=='R')
{
fin>>r[maxr],++maxr;
if(r[maxr]==xf)
}
else
{
fin>>a[maxa],++maxa;
if(a[maxa]==yf)
}
}
}
}
*/
int verif(int a,int b ,int c)
{
if((a+b)>=c&&(a+c)>=b&&(b+c)>=a)
return 1;
return 0;
}
int main()
{
int n;
fin>>n;
int v[n+1];
for(int i=0;i<n;i++)
fin>>v[i];
sort(v,v+n);
int i=0,k=0;
while(n-1-i)
{
int st=0,dr=n-1,mij;
while(st<=dr)
{
mij=(st+dr)/2;
if(verif(v[i],v[n-i-1],v[mij]))
k++,st=dr+5;
else if(v[mij]>v[i]+v[n-i-1])
dr=mij-1;
else
st=mij+1;
}
i++;
}
fout<<k;
}