Cod sursa(job #1210003)

Utilizator PopescuMihai95Popescu Mihai PopescuMihai95 Data 18 iulie 2014 23:32:58
Problema Trapez Scor 50
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.2 kb
#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=v[j].x-v[j].x,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;
}