Pagini recente » Diferente pentru home intre reviziile 678 si 679 | Istoria paginii runda/hardest_contest_ever1 | Cod sursa (job #2907079) | Statistici Albu Alexandru (1salut1) | Cod sursa (job #1330140)
#include<stdio.h>
#include<algorithm>
#define INF 666013
#define eps 0.0000000001
using namespace std;
int sol,l,nr,i,n;
struct punct
{
int x, y;
};
punct a[1004];
double v[1000*1000+4];
int main()
{
int j;
freopen("trapez.in","r",stdin);
freopen("trapez.out","w",stdout);
scanf("%d",&n);
for(i=1;i<=n;i++)
scanf("%d%d",&a[i].x,&a[i].y);
for(i=1;i<=n;i++)
for(j=i+1;j<=n;j++)
{
nr++;
if(a[i].y==a[j].y)
v[nr]=INF;
else
v[nr]=(double)(a[j].x-a[i].x)*1.0/(a[j].y-a[i].y);
}
sort(v+1,v+1+nr);
l=1;
for(int i=2;i<=nr;i++)
{
if(v[i]==v[i-1])
l++;
else{
sol+=l*(l-1)/2;
l=1;
}
}
sol+=l*(l-1)/2;
printf("%d",sol);
return 0;
}