10908 2024. 04. 18 19:54:00 gortomi Rajz cpp17 Hibás válasz 0/100 97ms 29924 KiB
#include <bits/stdc++.h>
using namespace std;
using ll = long long;
vector<int> p, r;
int n;
int get(int v)
{
    return p[v] == 0 ? v : p[v] = get(p[v]);
}
void unio(int a, int b)
{
    a = get(a);
    b = get(b);
    if(a != b)
    {
        if(r[a] < r[b]) swap(a, b);
        p[b] = a;
        if(r[a] == r[b]) r[a]++;
    }
}
struct val
{
    ll a, b, d;
};
bool insc(ll xa, ll xb, ll ya, ll yb)
{
    long double b = (yb - ya) / (xb - xa);
    if(b == 0) return 0;
    long double x = -1;
    //xa + (-ya / b);
    return x > 0;
}
int main()
{
    ios::sync_with_stdio(0);
    cin.tie(0);
    cin >> n;
    p.resize(2 * n + 1);
    r.resize(2 * n + 1);
    vector<ll> x(n + 1), y(n + 1);
    vector<val> e;
    for(int i = 1; i <= n; i++)
    {
        cin >> x[i] >> y[i];
        for(int j = 1; j < i; j++)
        {
            ll dx = x[i] - x[j], dy = y[i] - y[j];
            e.push_back({j, i, dx * dx + dy * dy});
        }
    }
    sort(e.begin(), e.end(), [](val a, val b)
    {
        return a.d < b.d;
    });
    for(auto [a, b, d] : e)
    {
        bool g = insc(x[a], x[b], y[a], y[b]);
        if(g)
        {
            unio(a, b + n);
            unio(a + n, b);
        }
        else
        {
            unio(a, b);
            unio(a + n, b + n);
        }
        if(get(a) == get(a + n))
        {
            cout << d << "\n";
            return 0;
        }
    }
    cout << "-1\n";
}
Részfeladat Összpont Teszt Verdikt Idő Memória
subtask1 0/0
1 Hibás válasz 3ms 1696 KiB
2 Hibás válasz 3ms 1932 KiB
subtask2 0/20
3 Hibás válasz 3ms 2160 KiB
4 Hibás válasz 3ms 2364 KiB
5 Hibás válasz 3ms 2584 KiB
6 Hibás válasz 3ms 2804 KiB
7 Hibás válasz 3ms 2960 KiB
8 Hibás válasz 3ms 3212 KiB
9 Hibás válasz 3ms 3276 KiB
10 Hibás válasz 3ms 3344 KiB
11 Elfogadva 3ms 3448 KiB
12 Elfogadva 3ms 3552 KiB
subtask3 0/20
13 Hibás válasz 3ms 2160 KiB
14 Hibás válasz 3ms 2364 KiB
15 Hibás válasz 3ms 2584 KiB
16 Hibás válasz 3ms 2804 KiB
17 Hibás válasz 3ms 2960 KiB
18 Hibás válasz 3ms 3212 KiB
19 Hibás válasz 3ms 3276 KiB
20 Hibás válasz 3ms 3344 KiB
21 Elfogadva 3ms 3448 KiB
22 Elfogadva 3ms 3552 KiB
23 Hibás válasz 3ms 3536 KiB
24 Hibás válasz 3ms 3756 KiB
25 Hibás válasz 3ms 3848 KiB
26 Hibás válasz 3ms 3840 KiB
27 Hibás válasz 3ms 3840 KiB
28 Hibás válasz 3ms 3736 KiB
29 Elfogadva 3ms 3824 KiB
30 Elfogadva 3ms 3820 KiB
31 Hibás válasz 3ms 3636 KiB
subtask4 0/20
32 Hibás válasz 3ms 2160 KiB
33 Hibás válasz 3ms 2364 KiB
34 Hibás válasz 3ms 2584 KiB
35 Hibás válasz 3ms 2804 KiB
36 Hibás válasz 3ms 2960 KiB
37 Hibás válasz 3ms 3212 KiB
38 Hibás válasz 3ms 3276 KiB
39 Hibás válasz 3ms 3344 KiB
40 Elfogadva 3ms 3448 KiB
41 Elfogadva 3ms 3552 KiB
42 Hibás válasz 3ms 3536 KiB
43 Hibás válasz 3ms 3756 KiB
44 Hibás válasz 3ms 3848 KiB
45 Hibás válasz 3ms 3840 KiB
46 Hibás válasz 3ms 3840 KiB
47 Hibás válasz 3ms 3736 KiB
48 Elfogadva 3ms 3824 KiB
49 Elfogadva 3ms 3820 KiB
50 Hibás válasz 3ms 3636 KiB
51 Hibás válasz 4ms 4096 KiB
52 Hibás válasz 3ms 4096 KiB
53 Hibás válasz 3ms 4384 KiB
54 Hibás válasz 4ms 4532 KiB
55 Hibás válasz 3ms 4408 KiB
56 Hibás válasz 3ms 4320 KiB
57 Hibás válasz 3ms 4344 KiB
58 Hibás válasz 3ms 4504 KiB
59 Hibás válasz 4ms 4552 KiB
60 Hibás válasz 3ms 4480 KiB
61 Hibás válasz 3ms 4472 KiB
62 Hibás válasz 3ms 4480 KiB
63 Hibás válasz 3ms 4732 KiB
64 Hibás válasz 3ms 4648 KiB
65 Hibás válasz 3ms 4656 KiB
66 Hibás válasz 3ms 4824 KiB
67 Elfogadva 3ms 4828 KiB
68 Elfogadva 3ms 4796 KiB
69 Elfogadva 3ms 4756 KiB
70 Elfogadva 3ms 4792 KiB
subtask5 0/40
71 Hibás válasz 3ms 2160 KiB
72 Hibás válasz 3ms 2364 KiB
73 Hibás válasz 3ms 2584 KiB
74 Hibás válasz 3ms 2804 KiB
75 Hibás válasz 3ms 2960 KiB
76 Hibás válasz 3ms 3212 KiB
77 Hibás válasz 3ms 3276 KiB
78 Hibás válasz 3ms 3344 KiB
79 Elfogadva 3ms 3448 KiB
80 Elfogadva 3ms 3552 KiB
81 Hibás válasz 3ms 3536 KiB
82 Hibás válasz 3ms 3756 KiB
83 Hibás válasz 3ms 3848 KiB
84 Hibás válasz 3ms 3840 KiB
85 Hibás válasz 3ms 3840 KiB
86 Hibás válasz 3ms 3736 KiB
87 Elfogadva 3ms 3824 KiB
88 Elfogadva 3ms 3820 KiB
89 Hibás válasz 3ms 3636 KiB
90 Hibás válasz 4ms 4096 KiB
91 Hibás válasz 3ms 4096 KiB
92 Hibás válasz 3ms 4384 KiB
93 Hibás válasz 4ms 4532 KiB
94 Hibás válasz 3ms 4408 KiB
95 Hibás válasz 3ms 4320 KiB
96 Hibás válasz 3ms 4344 KiB
97 Hibás válasz 3ms 4504 KiB
98 Hibás válasz 4ms 4552 KiB
99 Hibás válasz 3ms 4480 KiB
100 Hibás válasz 3ms 4472 KiB
101 Hibás válasz 3ms 4480 KiB
102 Hibás válasz 3ms 4732 KiB
103 Hibás válasz 3ms 4648 KiB
104 Hibás válasz 3ms 4656 KiB
105 Hibás válasz 3ms 4824 KiB
106 Elfogadva 3ms 4828 KiB
107 Elfogadva 3ms 4796 KiB
108 Elfogadva 3ms 4756 KiB
109 Elfogadva 3ms 4792 KiB
110 Hibás válasz 93ms 28964 KiB
111 Hibás válasz 93ms 29052 KiB
112 Hibás válasz 92ms 29056 KiB
113 Hibás válasz 87ms 29360 KiB
114 Hibás válasz 93ms 29448 KiB
115 Hibás válasz 89ms 29616 KiB
116 Hibás válasz 96ms 29792 KiB
117 Hibás válasz 97ms 29648 KiB
118 Hibás válasz 97ms 29616 KiB
119 Hibás válasz 93ms 29664 KiB
120 Hibás válasz 96ms 29588 KiB
121 Hibás válasz 93ms 29644 KiB
122 Hibás válasz 96ms 29632 KiB
123 Hibás válasz 96ms 29632 KiB
124 Hibás válasz 96ms 29628 KiB
125 Hibás válasz 92ms 29644 KiB
126 Hibás válasz 96ms 29592 KiB
127 Hibás válasz 92ms 29768 KiB
128 Elfogadva 94ms 29888 KiB
129 Hibás válasz 90ms 29800 KiB
130 Hibás válasz 94ms 29924 KiB
131 Elfogadva 72ms 29868 KiB
132 Elfogadva 94ms 29868 KiB