Submission #498487

#TimeUsernameProblemLanguageResultExecution timeMemory
498487KiprasCircle selection (APIO18_circle_selection)C++14
0 / 100
648 ms25512 KiB
#include <bits/stdc++.h> using namespace std; const int maxN = 3*1e5+1; int n; //radius, index, pos.x, pos.y set<pair<int, pair<int, pair<int, int>>>> a; int removedBy[maxN]; long long square(int a){ return a*a; } int main() { cin>>n; for(int i = 1; i <= n; i++){ int b, c, d; cin>>b>>c>>d; a.insert({-d, {i,{b, c}}}); } while(!a.empty()){ pair<int, pair<int, pair<int, int>>> temp = (*a.begin()); int r=temp.first, ind=temp.second.first, posX=temp.second.second.first, posY=temp.second.second.second; a.erase(a.begin()); removedBy[ind]=ind; vector<pair<int, pair<int, pair<int, int>>>> removeList; for(auto x : a){ if(square(abs(x.second.second.first-posX))+square(abs(x.second.second.second-posY))<=square((r*-1)+(x.first*-1)))removeList.push_back(x); } for(auto x : removeList){ a.erase(a.find(x)); removedBy[x.second.first]=ind; } } for(int i = 1; i <= n; i++){ cout<<removedBy[i]<<" "; } return 0; }
#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...