Cod sursa(job #2785489)

Utilizator UnknownPercentageBuca Mihnea-Vicentiu UnknownPercentage Data 18 octombrie 2021 19:32:22
Problema Trapez Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.9 kb
#include <bits/stdc++.h>

using namespace std;

inline void Open(const string Name) {
    #ifndef ONLINE_JUDGE
        (void)!freopen((Name + ".in").c_str(), "r", stdin);
        (void)!freopen((Name + ".out").c_str(), "w", stdout);
    #endif
}

double v[1000001];

int x[1001], y[1001];
int N, len, ans, cnt;

int main() {
    ios_base::sync_with_stdio(false);
    cin.tie(NULL);

    Open("trapez");

    cin >> N;
    for(int i = 1;i <= N;i++)
        cin >> x[i] >> y[i];


    for(int i = 1;i < N;i++)
        for(int j = i + 1;j <= N;j++) {
            double val = (double)(y[j] - y[i]) / (x[j] - x[i]);
            v[++len] = val;
        }

    sort(v + 1, v + len + 1);

    for(int i = 1;i <= len;i++)
        if(v[i] == v[i - 1]) cnt++;
        else {
            ans = ans + cnt * (cnt - 1) / 2;
            cnt = 1;
        }


    cout << ans;

    return 0;
}