Pagini recente » Monitorul de evaluare | Clasament simulare_upb_2009 | Diferente pentru home intre reviziile 517 si 902 | Istoria paginii utilizator/kissdarius | Cod sursa (job #448001)
Cod sursa(job #448001)
#include<fstream>
#include<algorithm>
using namespace std;
int v[808],n;
long long suma;
int caut(int j,int sum);
int main()
{
ifstream fin("nrtri.in");
ofstream fout("nrtri.out");
int i,j;
fin>>n;
for(i=1;i<=n;i++)
fin>>v[i];
sort(v+1,v+n+1);
for(i=1;i<=n-3;i++)
for(j=1;j<=n;j++)
{
int a,b,sum=0,poz=0;
a=v[i],b=v[j];
if(i!=j)
sum=a+b;
if(i!=j && sum>0)
poz=caut(j,sum);
//fout<<sum<<poz<<endl;
if(poz>0 && j!=i)
if(i==1 && sum>0)
suma+=poz-3;
else
if(sum>0)
suma+=poz-3;
}
fout<<suma;
return 0;
}
int caut(int j,int sum)
{
if(j==n)
return 0;
int i;
for(i=j;i<=n;i++)
if(v[i]>sum)
return i;
return n;
}