Pagini recente » Cod sursa (job #1264728) | Cod sursa (job #215263) | Cod sursa (job #1042699) | Cod sursa (job #1119650) | Cod sursa (job #1209998)
#include<cstdio>
#include<algorithm>
#define inf 2147000000
using namespace std;
int n,i,j;
long long nr,l,D,I,R,q;
struct nod
{
long long x;
long long y;
}v[1005],p[499555];
int cmp(const nod a,const nod b)
{
if (a.x==b.x) return a.y<=b.y;
return a.x<b.x;
}
int main()
{
freopen("trapez.in","r",stdin);
freopen("trapez.out","w",stdout);
scanf("%d",&n);
for (i=1;i<=n;i++)
{
scanf("%lld %lld",&v[i].x,&v[i].y);
for (j=i-1;j>=1;j--)
{
if (v[j].y==v[i].y) p[++l].x=0,p[l].y=0;
else
{
if (v[i].x==v[j].x) {p[++l].x=inf; p[l].y=inf; continue;}
p[++l].x=(v[j].x-v[i].x);
p[l].y=(v[j].y-v[i].y);
D=p[l].x; I=p[l].y; R=D%I;
while (R) D=I,I=R,R=D%I;
p[l].x=p[l].x/I;
p[l].y=p[l].y/I;
}
}
}
sort(p+1,p+l+1,cmp);
long long sol=0ll;
for (i=2;i<=l;i++)
{
if ((p[i].x!=p[i-1].x)&&(sol)) nr=nr+((sol+1)*sol)/2,sol=0;
if ((p[i].x==p[i-1].x)&&(p[i].y==p[i-1].y)) sol++;
}
printf("%lld",nr);
return 0;
}