Cod sursa(job #2062531)

Utilizator FunnyStockyMihnea Andreescu FunnyStocky Data 10 noiembrie 2017 16:03:38
Problema Trapez Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.76 kb
#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;
}