Pagini recente » Cod sursa (job #2545832) | Cod sursa (job #105960) | Cod sursa (job #1783484) | Cod sursa (job #2226957) | Cod sursa (job #712672)
Cod sursa(job #712672)
#include<fstream>
#include<algorithm>
#include<cmath>
using namespace std;
ifstream f("trapez.in");
ofstream g("trapez.out");
int N,i,j,x[1001],y[1001],k=0,trapez=0,r=0;
float pante[1000001];
float lung[1000001];
void citire()
{
f>>N;
for (i=1;i<=N;i++)
f>>x[i]>>y[i];
}
void panta()
{
for (i=1;i<=N-1;i++)
for (j=i+1;j<=N;j++)
{
if (x[i]==x[j]) pante[++k]=9999991;
else pante[++k]=(float)(y[j]-y[i])/(x[j]-x[i]);
lung[k]=sqrt((float)(y[j]-y[i])*(y[j]-y[i])+(float)(x[j]-x[i])*(x[j]-x[i]));
}
}
void caut()
{
trapez=0;
for (i=1;i<=k;i++)
{
r=1;
while (pante[i]==pante[i+1])
{
r++;
trapez+=r-1;
if (lung[i]==lung[i+1]) trapez++;
i++;
}
}
}
int main()
{
citire();
panta();
sort (pante+1,pante+k+1);
caut();
g<<trapez;
return 0;
}