Pagini recente » Cod sursa (job #461357) | Cod sursa (job #2909021) | Cod sursa (job #3168860) | Cod sursa (job #965534) | Cod sursa (job #457219)
Cod sursa(job #457219)
#include<stdio.h>
#include<algorithm>
int b[802];
using namespace std;
int main()
{
freopen("nrtri.in","r",stdin);
freopen("nrtri.out","w",stdout);
int c=0,a,d,i,j,n,m,u,p,x,y;
scanf("%d",&n);
for(i=1;i<=n;i++)
scanf("%d",&b[i]);
sort(b+1,b+n+1);
for(i=1;i<n;i++)
for(j=i+1;j<=n;j++)
{
u=n;
p=1;
x=b[i]+b[j];
y=b[j]-b[i];
while(p<=u)
{
m=(u+p)/2;
if(b[m]>=y)
u=m-1;
else
p=m+1;
}
a = u;
p=1;
u=n;
while(p<=u)
{
m=(u+p)/2;
if(b[m]<=x)
p=m+1;
else
u=m-1;
}
c=c+u-a-1;
}
printf("%d",c/2);
return 0;
}