// 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();
}
| Subtask | Sum | Test | Verdict | Time | Memory | ||
|---|---|---|---|---|---|---|---|
| subtask1 | 0/0 | ||||||
| 1 | Accepted | 1ms | 316 KiB | ||||
| 2 | Accepted | 1ms | 316 KiB | ||||
| subtask2 | 20/20 | ||||||
| 3 | Accepted | 1ms | 316 KiB | ||||
| 4 | Accepted | 1ms | 316 KiB | ||||
| 5 | Accepted | 1ms | 316 KiB | ||||
| 6 | Accepted | 1ms | 316 KiB | ||||
| 7 | Accepted | 1ms | 316 KiB | ||||
| 8 | Accepted | 1ms | 316 KiB | ||||
| 9 | Accepted | 1ms | 316 KiB | ||||
| 10 | Accepted | 1ms | 316 KiB | ||||
| 11 | Accepted | 1ms | 316 KiB | ||||
| 12 | Accepted | 1ms | 392 KiB | ||||
| subtask3 | 20/20 | ||||||
| 13 | Accepted | 1ms | 316 KiB | ||||
| 14 | Accepted | 1ms | 316 KiB | ||||
| 15 | Accepted | 1ms | 316 KiB | ||||
| 16 | Accepted | 1ms | 316 KiB | ||||
| 17 | Accepted | 1ms | 316 KiB | ||||
| 18 | Accepted | 1ms | 316 KiB | ||||
| 19 | Accepted | 1ms | 316 KiB | ||||
| 20 | Accepted | 1ms | 316 KiB | ||||
| 21 | Accepted | 1ms | 316 KiB | ||||
| 22 | Accepted | 1ms | 392 KiB | ||||
| 23 | Accepted | 1ms | 316 KiB | ||||
| 24 | Accepted | 1ms | 316 KiB | ||||
| 25 | Accepted | 1ms | 388 KiB | ||||
| 26 | Accepted | 1ms | 316 KiB | ||||
| 27 | Accepted | 1ms | 316 KiB | ||||
| 28 | Accepted | 1ms | 556 KiB | ||||
| 29 | Accepted | 1ms | 316 KiB | ||||
| 30 | Accepted | 1ms | 316 KiB | ||||
| 31 | Accepted | 1ms | 316 KiB | ||||
| subtask4 | 20/20 | ||||||
| 32 | Accepted | 1ms | 316 KiB | ||||
| 33 | Accepted | 1ms | 316 KiB | ||||
| 34 | Accepted | 1ms | 316 KiB | ||||
| 35 | Accepted | 1ms | 316 KiB | ||||
| 36 | Accepted | 1ms | 316 KiB | ||||
| 37 | Accepted | 1ms | 316 KiB | ||||
| 38 | Accepted | 1ms | 316 KiB | ||||
| 39 | Accepted | 1ms | 316 KiB | ||||
| 40 | Accepted | 1ms | 316 KiB | ||||
| 41 | Accepted | 1ms | 392 KiB | ||||
| 42 | Accepted | 1ms | 316 KiB | ||||
| 43 | Accepted | 1ms | 316 KiB | ||||
| 44 | Accepted | 1ms | 388 KiB | ||||
| 45 | Accepted | 1ms | 316 KiB | ||||
| 46 | Accepted | 1ms | 316 KiB | ||||
| 47 | Accepted | 1ms | 556 KiB | ||||
| 48 | Accepted | 1ms | 316 KiB | ||||
| 49 | Accepted | 1ms | 316 KiB | ||||
| 50 | Accepted | 1ms | 316 KiB | ||||
| 51 | Accepted | 2ms | 784 KiB | ||||
| 52 | Accepted | 2ms | 564 KiB | ||||
| 53 | Accepted | 2ms | 592 KiB | ||||
| 54 | Accepted | 2ms | 564 KiB | ||||
| 55 | Accepted | 2ms | 564 KiB | ||||
| 56 | Accepted | 2ms | 576 KiB | ||||
| 57 | Accepted | 2ms | 564 KiB | ||||
| 58 | Accepted | 2ms | 564 KiB | ||||
| 59 | Accepted | 2ms | 564 KiB | ||||
| 60 | Accepted | 2ms | 564 KiB | ||||
| 61 | Accepted | 2ms | 564 KiB | ||||
| 62 | Accepted | 2ms | 564 KiB | ||||
| 63 | Accepted | 2ms | 564 KiB | ||||
| 64 | Accepted | 2ms | 564 KiB | ||||
| 65 | Accepted | 2ms | 564 KiB | ||||
| 66 | Accepted | 3ms | 564 KiB | ||||
| 67 | Accepted | 3ms | 564 KiB | ||||
| 68 | Accepted | 3ms | 564 KiB | ||||
| 69 | Accepted | 3ms | 564 KiB | ||||
| 70 | Accepted | 3ms | 572 KiB | ||||
| subtask5 | 40/40 | ||||||
| 71 | Accepted | 1ms | 316 KiB | ||||
| 72 | Accepted | 1ms | 316 KiB | ||||
| 73 | Accepted | 1ms | 316 KiB | ||||
| 74 | Accepted | 1ms | 316 KiB | ||||
| 75 | Accepted | 1ms | 316 KiB | ||||
| 76 | Accepted | 1ms | 316 KiB | ||||
| 77 | Accepted | 1ms | 316 KiB | ||||
| 78 | Accepted | 1ms | 316 KiB | ||||
| 79 | Accepted | 1ms | 316 KiB | ||||
| 80 | Accepted | 1ms | 392 KiB | ||||
| 81 | Accepted | 1ms | 316 KiB | ||||
| 82 | Accepted | 1ms | 316 KiB | ||||
| 83 | Accepted | 1ms | 388 KiB | ||||
| 84 | Accepted | 1ms | 316 KiB | ||||
| 85 | Accepted | 1ms | 316 KiB | ||||
| 86 | Accepted | 1ms | 556 KiB | ||||
| 87 | Accepted | 1ms | 316 KiB | ||||
| 88 | Accepted | 1ms | 316 KiB | ||||
| 89 | Accepted | 1ms | 316 KiB | ||||
| 90 | Accepted | 2ms | 784 KiB | ||||
| 91 | Accepted | 2ms | 564 KiB | ||||
| 92 | Accepted | 2ms | 592 KiB | ||||
| 93 | Accepted | 2ms | 564 KiB | ||||
| 94 | Accepted | 2ms | 564 KiB | ||||
| 95 | Accepted | 2ms | 576 KiB | ||||
| 96 | Accepted | 2ms | 564 KiB | ||||
| 97 | Accepted | 2ms | 564 KiB | ||||
| 98 | Accepted | 2ms | 564 KiB | ||||
| 99 | Accepted | 2ms | 564 KiB | ||||
| 100 | Accepted | 2ms | 564 KiB | ||||
| 101 | Accepted | 2ms | 564 KiB | ||||
| 102 | Accepted | 2ms | 564 KiB | ||||
| 103 | Accepted | 2ms | 564 KiB | ||||
| 104 | Accepted | 2ms | 564 KiB | ||||
| 105 | Accepted | 3ms | 564 KiB | ||||
| 106 | Accepted | 3ms | 564 KiB | ||||
| 107 | Accepted | 3ms | 564 KiB | ||||
| 108 | Accepted | 3ms | 564 KiB | ||||
| 109 | Accepted | 3ms | 572 KiB | ||||
| 110 | Accepted | 158ms | 8596 KiB | ||||
| 111 | Accepted | 160ms | 8596 KiB | ||||
| 112 | Accepted | 162ms | 8596 KiB | ||||
| 113 | Accepted | 158ms | 8608 KiB | ||||
| 114 | Accepted | 165ms | 8592 KiB | ||||
| 115 | Accepted | 159ms | 8600 KiB | ||||
| 116 | Accepted | 163ms | 8596 KiB | ||||
| 117 | Accepted | 166ms | 8724 KiB | ||||
| 118 | Accepted | 163ms | 8652 KiB | ||||
| 119 | Accepted | 168ms | 8596 KiB | ||||
| 120 | Accepted | 159ms | 8636 KiB | ||||
| 121 | Accepted | 163ms | 8560 KiB | ||||
| 122 | Accepted | 170ms | 8596 KiB | ||||
| 123 | Accepted | 168ms | 8596 KiB | ||||
| 124 | Accepted | 172ms | 8596 KiB | ||||
| 125 | Accepted | 158ms | 8596 KiB | ||||
| 126 | Accepted | 273ms | 8596 KiB | ||||
| 127 | Accepted | 268ms | 8596 KiB | ||||
| 128 | Accepted | 291ms | 8596 KiB | ||||
| 129 | Accepted | 319ms | 8696 KiB | ||||
| 130 | Accepted | 266ms | 8596 KiB | ||||
| 131 | Accepted | 263ms | 8596 KiB | ||||
| 132 | Accepted | 337ms | 8596 KiB | ||||