Pagini recente » Cod sursa (job #2046768) | Istoria paginii utilizator/mihaicaracuda | Cod sursa (job #2170744) | Diferente pentru runda/redsnow_2 intre reviziile 37 si 38 | Cod sursa (job #1482885)
#include <iostream>
#include <fstream>
#include <algorithm>
using namespace std;
ifstream f("nrtri.in");
ofstream g("nrtri.out");
int a[860],n,nrsol;
void Cautbin(int x1, int x2)
{
int sum,ps,pd,mid;
sum=a[x1]+a[x2];
ps=max(x1,x2);
pd=n;
while (ps<=pd)
{
mid=(ps+pd)/2;
if (a[mid]>sum) pd=mid-1;
if (a[mid]<=sum) ps=mid+1;
}
mid=(ps+pd)/2;
if (a[mid]>sum) mid--;
nrsol=mid-max(x1,x2)+nrsol;
}
int main()
{
int i,j;
f>>n;
for (i=1;i<=n;i++)
{
f>>a[i];
}
sort (a+1,a+n+1);
for (i=1;i<=n-2;i++)
{
for (j=i+1;j<=n-1;j++)
{
Cautbin(i,j);
}
}
g<<nrsol;
return 0;
}