Pagini recente » Cod sursa (job #2566300) | Cod sursa (job #3180673) | Cod sursa (job #478188) | Cod sursa (job #2910250) | Cod sursa (job #2062531)
#include <fstream>
#include <iostream>
#include <algorithm>
using namespace std;
ifstream fin("q.in");
ofstream fout("q.out");
const int nm=1000;
int n,t,sum,sol;
double mat[nm*nm+5];
struct fint
{
double x,y;
};
fint v[nm];
int main()
{
fin>>n;
for(int i=1;i<=n;i++)
fin>>v[i].x>>v[i].y;
for(int i=1;i<=n;i++)
for(int j=i+1;j<=n;j++)
{
mat[++t]=(v[i].x-v[j].x)/(v[i].y-v[j].y);
}
sort(mat+1,mat+t+1);
mat[t+1]=1e5+1e4;
for(int i=1;i<=t;i++)
{
if(mat[i]==mat[i+1])
sum++;
else
{
sol+=sum*(sum+1)/2;
sum=0;
}
}
fout<<sol;
return 0;
}