Cod sursa(job #1332534)

Utilizator wGEORGEWGeorge Cioti wGEORGEW Data 2 februarie 2015 09:58:13
Problema Trapez Scor 60
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.91 kb
#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;
 
 
}