Pagini recente » Cod sursa (job #2626022) | Cod sursa (job #2720104) | Cod sursa (job #2850556) | Cod sursa (job #2367691) | Cod sursa (job #1725774)
#include<bits/stdc++.h>
using namespace std;
int n,v[805],l,ls,ld,sol,m,nrtri;
int main()
{
freopen("nrtri.in","r",stdin);
freopen("nrtri.out","w",stdout);
scanf("%d",&n);
for(int i=1;i<=n;i++)
{
scanf("%d",&v[i]);
}
sort(v+1,v+n+1);
for(int i=1;i<=(n-2);i++)
{
for(int j=i+1;j<=(n-1);j++)
{
l=v[i]+v[j]-1;
ls=j+1;
ld=n;
sol=0;
while (ls<ld)
{
m=ls+(ld-ls)/2;
if (v[m]<=l)
{
sol=m;
ld=m-1;
}
else ls=m+1;
}
if (sol) nrtri=nrtri+sol-i;
}
}
printf("%d\n",nrtri);
return 0;
}