Pagini recente » Cod sursa (job #195430) | Cod sursa (job #2800344) | Cod sursa (job #1260386) | Cod sursa (job #214717) | Cod sursa (job #2486396)
#include <iostream>
#include <fstream>
using namespace std;
int n,v[100001],ans=0,k;
ifstream f("nrtri.in");
ofstream g("nrtri.out");
int cautare(int x,int i)
{
int st=i,dr=n,m;
while(st<=dr)
{
m=(st+dr)/2;
if(v[m]>x)
dr=m-1;
else
st=m+1;
}
return dr;
}
int main()
{
f>>n;
for(int i=1; i<=n; i++)
f>>v[i];
for(int i=1; i<n; i++)
for(int j=i+1; j<=n; j++)
{
if(v[i]>v[j])
{
int aux=v[i];
v[i]=v[j];
v[j]=aux;
}
}
for(int i=1; i<n; i++)
for(int j=i+1; j<=n; j++)
{
k=cautare(v[i]+v[j],j);
ans+=k-j;
}
g<<ans;
return 0;
}