Submission #107293

#TimeUsernameProblemLanguageResultExecution timeMemory
107293leduykhongnguCircle selection (APIO18_circle_selection)C++11
72 / 100
3016 ms66124 KiB
#include <bits/stdc++.h> #define FOR(i,a,b) for (int i=(a),_b=(b); i<=_b; ++i) #define FORR(i,a,b) for (int i=(a),_b=(b); i>=_b; --i) #define REP(i,b) for (int i=0,_b=(b); i<_b; ++i) #define endl '\n' #define sz(x) (int) x.size() #define mod % #define fillchar(x,y,z) memset(x,z,y) #define pii pair<int,int> #define fi first #define se second #define mp make_pair typedef long long int64; typedef unsigned long long qword; using namespace std; int ReadInt() { char c; for (c = getchar(); c!='-'&&(c < '0' || c > '9'); c = getchar()); int nega=0; int ans = c - '0'; if (c=='-') nega=1,ans=0; for (c = getchar(); c >= '0' && c <= '9'; c = getchar()) ans = ans * 10 + c - '0'; if (nega) return -ans; return ans; } void WriteInt(int x) { if (x > 9) WriteInt(x / 10); putchar(x % 10 + '0'); } const int maxn=3e5+5; inline int64 sqr(int64 x) { return x*x; } struct Circle{ int64 x,y,r; int id; bool IsIntersect(const Circle &c) { return sqr(x-c.x)+sqr(y-c.y)<=sqr(r+c.r); } }cir[maxn]; bool operator <(const Circle &b,const Circle &c) { return mp(-b.r,b.id)<mp(-c.r,c.id); } vector<set<pii> > Point; vector<int> X; int n; int ans[maxn]; pii tmp[maxn]; int main() { #ifdef meomeomeooooo freopen("input.txt","r",stdin); //freopen(".txt","w",stdout); #endif // meomeomeooooo iostream::sync_with_stdio(false); cin.tie(0); n=ReadInt(); set<Circle> myset; FOR(i,1,n) { //cin >> cir[i].x >> cir[i].y >> cir[i].r; cir[i].x=ReadInt(); cir[i].y=ReadInt(); cir[i].r=ReadInt(); X.push_back(cir[i].x); cir[i].id=i; myset.insert(cir[i]); } sort(X.begin(),X.end()); X.resize(unique(X.begin(),X.end())-X.begin()); #define GetDec(x) (lower_bound(X.begin(),X.end(),x)-X.begin()) Point.resize(X.size()); FOR(i,1,n) { int x=GetDec(cir[i].x); Point[x].insert({cir[i].y,cir[i].id}); } while (myset.size()) { Circle cur=*myset.begin(); myset.erase(cur); ans[cur.id]=cur.id; int x=cur.x,y=cur.y,r=cur.r; int Lx=max(1ll*x-2*r,-1000000000ll); int Rx=min(1ll*x+2*r,1000000000ll); int Ly=max(1ll*y-2*r,-1000000000ll); int Ry=min(1ll*y+2*r,1000000000ll); Lx=GetDec(Lx); for (int i=Lx; i<X.size()&&X[i]<=Rx; ++i) { int top=0; for (auto j=Point[i].lower_bound(mp(Ly,0)); j!=Point[i].end()&&(*j).fi<=Ry; ++j) { int id=(*j).se; if (cur.IsIntersect(cir[id])) { assert(ans[id]==0||ans[id]==cur.id); ans[id]=cur.id; myset.erase(cir[id]); tmp[++top]=*j; } } FOR(j,1,top) Point[i].erase(tmp[j]); } } FOR(i,1,n) { WriteInt(ans[i]); putchar(' '); } return 0; }

Compilation message (stderr)

circle_selection.cpp: In function 'int main()':
circle_selection.cpp:90:25: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
         for (int i=Lx; i<X.size()&&X[i]<=Rx; ++i) {
                        ~^~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...