Pagini recente » Cod sursa (job #1787857) | Cod sursa (job #798676) | Cod sursa (job #2491020) | Cod sursa (job #373685) | Cod sursa (job #518652)
Cod sursa(job #518652)
#include <fstream>
using namespace std;
int v[801];
/*int binar(int s, int ls)
{
int ld=n;
while(ls<=ld)
{
int mijloc=(ls+ld)/2;
if((v[mijloc]<=s && v[mijloc+1]>s) || (mijloc==n && v[mijloc]<=s))
return mijloc;
else
if(v[mijloc]<=s && v[mijloc+1]<=s)
ls=mijloc+1;
else
ld=mijloc-1;
}
}*/
int main()
{
ifstream fin("nrtri.in");
ofstream fout("nrtri.out");
int i, j,nr,n;
fin>>n;
for(i=1;i<=n;++i)
fin>>v[i];
sort(v+1,v+n+1);
nr=0;
for(i=1;i<=n-2;++i)
for(j=i+1;j<=n-1;++j)
{
int k=j+1;
while(v[i]+v[j]>=v[k] && k<=n)
++k;
nr+=k-j-1;
}
//nr+=binar(v[i]+v[j],j)-j;
fout<<nr;
return 0;
}