Pagini recente » Cod sursa (job #702804) | Cod sursa (job #1711417) | Cod sursa (job #2594873) | Cod sursa (job #2872749) | Cod sursa (job #1220203)
#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;
}