// Source: https://usaco.guide/general/io
#include <bits/stdc++.h>
using namespace std;
using ll=long long;
struct pont{
ll x,y;
};
vector<pont> v;
int fordul(pont a,pont b){
ll s=a.x*b.y-a.y*b.x;
return (s>0)-(s<0);
}
int val(pont a,pont b){
if (a.y>b.y) swap(a,b);
if (a.y<0 && b.y>=0 && fordul(a,b)==1) return 1;
return 0;
}
ll dist(int a, int b){
ll x = v[a].x-v[b].x;
ll y = v[a].y-v[b].y;
return x*x+y*y;
}
struct edge{
ll a,b;
ll len() const {
ll x = v[a].x-v[b].x;
ll y = v[a].y-v[b].y;
return x*x+y*y;
}
auto operator< (const edge &other) {
return len()<other.len();
}
};
vector<edge> e;
vector<int> c;
int n;
bool dfs(int cs, ll d){
for (int to=0;to<n;to++){
if (to==cs) continue;
if (dist(cs,to)>d) continue;
if (c[to]!=-1){
if ((val(v[cs], v[to])+c[cs]+c[to])%2) return false;
continue;
}
if (val(v[cs], v[to])) c[to]=1-c[cs];
else c[to]=c[cs];
if (!dfs(to,d)) return false;
}
return true;
}
int main() {
cin>>n;
v.resize(n);
c.resize(n,-1);
for (auto &i : v) cin>>i.x>>i.y;
for (int i=0;i<n;i++){
for (int j=i+1;j<n;j++){
e.push_back({i,j});
}
}
sort(e.begin(), e.end());
ll l=-1,r=e.size();
while (l+1<r){
ll mid=(l+r)/2;
c.assign(n,-1);
bool kor=true;
for (int i=0;i<n;i++) if(c[i]==-1) {
c[i]=0;
kor = min(dfs(i, e[mid].len()),kor);
}
if (!kor){
r=mid;
}
else {
l=mid;
}
}
if (r==e.size()){
cout<<-1;
return 0;
}
cout<<e[r].len();
}
Részfeladat | Összpont | Teszt | Verdikt | Idő | Memória | ||
---|---|---|---|---|---|---|---|
subtask1 | 0/0 | ||||||
1 | Elfogadva | 1ms | 316 KiB | ||||
2 | Elfogadva | 1ms | 316 KiB | ||||
subtask2 | 20/20 | ||||||
3 | Elfogadva | 1ms | 316 KiB | ||||
4 | Elfogadva | 1ms | 316 KiB | ||||
5 | Elfogadva | 1ms | 316 KiB | ||||
6 | Elfogadva | 1ms | 316 KiB | ||||
7 | Elfogadva | 1ms | 316 KiB | ||||
8 | Elfogadva | 1ms | 316 KiB | ||||
9 | Elfogadva | 1ms | 316 KiB | ||||
10 | Elfogadva | 1ms | 316 KiB | ||||
11 | Elfogadva | 1ms | 316 KiB | ||||
12 | Elfogadva | 1ms | 392 KiB | ||||
subtask3 | 20/20 | ||||||
13 | Elfogadva | 1ms | 316 KiB | ||||
14 | Elfogadva | 1ms | 316 KiB | ||||
15 | Elfogadva | 1ms | 316 KiB | ||||
16 | Elfogadva | 1ms | 316 KiB | ||||
17 | Elfogadva | 1ms | 316 KiB | ||||
18 | Elfogadva | 1ms | 316 KiB | ||||
19 | Elfogadva | 1ms | 316 KiB | ||||
20 | Elfogadva | 1ms | 316 KiB | ||||
21 | Elfogadva | 1ms | 316 KiB | ||||
22 | Elfogadva | 1ms | 392 KiB | ||||
23 | Elfogadva | 1ms | 316 KiB | ||||
24 | Elfogadva | 1ms | 316 KiB | ||||
25 | Elfogadva | 1ms | 388 KiB | ||||
26 | Elfogadva | 1ms | 316 KiB | ||||
27 | Elfogadva | 1ms | 316 KiB | ||||
28 | Elfogadva | 1ms | 556 KiB | ||||
29 | Elfogadva | 1ms | 316 KiB | ||||
30 | Elfogadva | 1ms | 316 KiB | ||||
31 | Elfogadva | 1ms | 316 KiB | ||||
subtask4 | 20/20 | ||||||
32 | Elfogadva | 1ms | 316 KiB | ||||
33 | Elfogadva | 1ms | 316 KiB | ||||
34 | Elfogadva | 1ms | 316 KiB | ||||
35 | Elfogadva | 1ms | 316 KiB | ||||
36 | Elfogadva | 1ms | 316 KiB | ||||
37 | Elfogadva | 1ms | 316 KiB | ||||
38 | Elfogadva | 1ms | 316 KiB | ||||
39 | Elfogadva | 1ms | 316 KiB | ||||
40 | Elfogadva | 1ms | 316 KiB | ||||
41 | Elfogadva | 1ms | 392 KiB | ||||
42 | Elfogadva | 1ms | 316 KiB | ||||
43 | Elfogadva | 1ms | 316 KiB | ||||
44 | Elfogadva | 1ms | 388 KiB | ||||
45 | Elfogadva | 1ms | 316 KiB | ||||
46 | Elfogadva | 1ms | 316 KiB | ||||
47 | Elfogadva | 1ms | 556 KiB | ||||
48 | Elfogadva | 1ms | 316 KiB | ||||
49 | Elfogadva | 1ms | 316 KiB | ||||
50 | Elfogadva | 1ms | 316 KiB | ||||
51 | Elfogadva | 2ms | 784 KiB | ||||
52 | Elfogadva | 2ms | 564 KiB | ||||
53 | Elfogadva | 2ms | 592 KiB | ||||
54 | Elfogadva | 2ms | 564 KiB | ||||
55 | Elfogadva | 2ms | 564 KiB | ||||
56 | Elfogadva | 2ms | 576 KiB | ||||
57 | Elfogadva | 2ms | 564 KiB | ||||
58 | Elfogadva | 2ms | 564 KiB | ||||
59 | Elfogadva | 2ms | 564 KiB | ||||
60 | Elfogadva | 2ms | 564 KiB | ||||
61 | Elfogadva | 2ms | 564 KiB | ||||
62 | Elfogadva | 2ms | 564 KiB | ||||
63 | Elfogadva | 2ms | 564 KiB | ||||
64 | Elfogadva | 2ms | 564 KiB | ||||
65 | Elfogadva | 2ms | 564 KiB | ||||
66 | Elfogadva | 3ms | 564 KiB | ||||
67 | Elfogadva | 3ms | 564 KiB | ||||
68 | Elfogadva | 3ms | 564 KiB | ||||
69 | Elfogadva | 3ms | 564 KiB | ||||
70 | Elfogadva | 3ms | 572 KiB | ||||
subtask5 | 40/40 | ||||||
71 | Elfogadva | 1ms | 316 KiB | ||||
72 | Elfogadva | 1ms | 316 KiB | ||||
73 | Elfogadva | 1ms | 316 KiB | ||||
74 | Elfogadva | 1ms | 316 KiB | ||||
75 | Elfogadva | 1ms | 316 KiB | ||||
76 | Elfogadva | 1ms | 316 KiB | ||||
77 | Elfogadva | 1ms | 316 KiB | ||||
78 | Elfogadva | 1ms | 316 KiB | ||||
79 | Elfogadva | 1ms | 316 KiB | ||||
80 | Elfogadva | 1ms | 392 KiB | ||||
81 | Elfogadva | 1ms | 316 KiB | ||||
82 | Elfogadva | 1ms | 316 KiB | ||||
83 | Elfogadva | 1ms | 388 KiB | ||||
84 | Elfogadva | 1ms | 316 KiB | ||||
85 | Elfogadva | 1ms | 316 KiB | ||||
86 | Elfogadva | 1ms | 556 KiB | ||||
87 | Elfogadva | 1ms | 316 KiB | ||||
88 | Elfogadva | 1ms | 316 KiB | ||||
89 | Elfogadva | 1ms | 316 KiB | ||||
90 | Elfogadva | 2ms | 784 KiB | ||||
91 | Elfogadva | 2ms | 564 KiB | ||||
92 | Elfogadva | 2ms | 592 KiB | ||||
93 | Elfogadva | 2ms | 564 KiB | ||||
94 | Elfogadva | 2ms | 564 KiB | ||||
95 | Elfogadva | 2ms | 576 KiB | ||||
96 | Elfogadva | 2ms | 564 KiB | ||||
97 | Elfogadva | 2ms | 564 KiB | ||||
98 | Elfogadva | 2ms | 564 KiB | ||||
99 | Elfogadva | 2ms | 564 KiB | ||||
100 | Elfogadva | 2ms | 564 KiB | ||||
101 | Elfogadva | 2ms | 564 KiB | ||||
102 | Elfogadva | 2ms | 564 KiB | ||||
103 | Elfogadva | 2ms | 564 KiB | ||||
104 | Elfogadva | 2ms | 564 KiB | ||||
105 | Elfogadva | 3ms | 564 KiB | ||||
106 | Elfogadva | 3ms | 564 KiB | ||||
107 | Elfogadva | 3ms | 564 KiB | ||||
108 | Elfogadva | 3ms | 564 KiB | ||||
109 | Elfogadva | 3ms | 572 KiB | ||||
110 | Elfogadva | 158ms | 8596 KiB | ||||
111 | Elfogadva | 160ms | 8596 KiB | ||||
112 | Elfogadva | 162ms | 8596 KiB | ||||
113 | Elfogadva | 158ms | 8608 KiB | ||||
114 | Elfogadva | 165ms | 8592 KiB | ||||
115 | Elfogadva | 159ms | 8600 KiB | ||||
116 | Elfogadva | 163ms | 8596 KiB | ||||
117 | Elfogadva | 166ms | 8724 KiB | ||||
118 | Elfogadva | 163ms | 8652 KiB | ||||
119 | Elfogadva | 168ms | 8596 KiB | ||||
120 | Elfogadva | 159ms | 8636 KiB | ||||
121 | Elfogadva | 163ms | 8560 KiB | ||||
122 | Elfogadva | 170ms | 8596 KiB | ||||
123 | Elfogadva | 168ms | 8596 KiB | ||||
124 | Elfogadva | 172ms | 8596 KiB | ||||
125 | Elfogadva | 158ms | 8596 KiB | ||||
126 | Elfogadva | 273ms | 8596 KiB | ||||
127 | Elfogadva | 268ms | 8596 KiB | ||||
128 | Elfogadva | 291ms | 8596 KiB | ||||
129 | Elfogadva | 319ms | 8696 KiB | ||||
130 | Elfogadva | 266ms | 8596 KiB | ||||
131 | Elfogadva | 263ms | 8596 KiB | ||||
132 | Elfogadva | 337ms | 8596 KiB |