Cod sursa(job #1220203)

Utilizator ovidiuz98Zamfir Ovidiu ovidiuz98 Data 16 august 2014 20:27:54
Problema Trapez Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.87 kb
#include <fstream>
using namespace std;
ifstream f("trapez.in");
ofstream g("trapez.out");
struct punct{long x,y;}a[1002];
int n,i,j,k=1,l;
double b[500000];
long nr;
double panta(punct p1,punct p2)
{
    return (float)(p1.y-p2.y)/(p1.x-p2.x);
}
int part(int l,int r)
{
    int i,j;
    double p;
    p=b[r];
    j=l-1;
    for(i=l;i<=r;i++)
        if(b[i]<=p) swap(b[++j],b[i]);
    return j;
}
void quick(int l,int r)
{
    int poz;
    poz=part(l,r);
    if(l<poz-1)
        quick(l,poz-1);
    if(r>poz+1)
        quick(poz+1,r);
}
int main()
{
    f>>n;
    for(i=1;i<=n;i++) f>>a[i].x>>a[i].y;
    for(i=1;i<n;i++)
        for(j=i+1;j<=n;j++)
        b[++l]=panta(a[i],a[j]);
    quick(1,l);
    for(i=2;i<=l;i++)
    {
        if(b[i]==b[i-1]) k++;
        else nr+=k*(k-1)/2,k=1;
    }
    g<<nr;
    f.close();g.close();
    return 0;
}