Pagini recente » Cod sursa (job #2762948) | Cod sursa (job #3280274) | Cod sursa (job #2313011) | Cod sursa (job #359480) | Cod sursa (job #1332534)
#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]>-eps&&v[i]-v[i-1]<eps)
l++;
else{
sol+=l*(l-1)/2;
l=1;
}
}
sol+=l*(l-1)/2;
printf("%d",sol);
return 0;
}