Submission #491684

#TimeUsernameProblemLanguageResultExecution timeMemory
491684MeGustaElArroz23Fountain Parks (IOI21_parks)C++17
100 / 100
782 ms94420 KiB
#include "parks.h" #include<bits/stdc++.h> using namespace std; #define vi vector<int> #define pii pair<int,int> #define vii vector<pii> #define fi first #define se second class dsu{ public: vi ind; vi size; dsu(int n){ ind=vi(n); for (int i=0;i<n;i++) ind[i]=i; size=vi(n,1); } int find(int x){ if (ind[x]==x) return x; ind[x]=find(ind[x]); return ind[x]; } void unite(int a, int b){ a=find(a); b=find(b); if (a==b) return; if (size[a]<size[b]) swap(a,b); size[a]+=size[b]; ind[b]=a; } }; int construct_roads(vi cordx, vi cordy){ int n=cordx.size(); vii v(n); for (int i=0;i<n;i++) v[i]=pii{cordx[i],cordy[i]}; vi u; //ind fuentes vi w; vi a; // coord banco vi b; map<pii,int> indfuente; for (int i=0;i<n;i++) indfuente[v[i]]=i+1; set<pii> posiblesbancos; for (pii p:v){ posiblesbancos.insert(pii{p.fi+1,p.se+1}); posiblesbancos.insert(pii{p.fi+1,p.se-1}); posiblesbancos.insert(pii{p.fi-1,p.se+1}); posiblesbancos.insert(pii{p.fi-1,p.se-1}); } for (pii p:posiblesbancos){ if ((p.fi+p.se)%4==0){ if (indfuente[pii{p.fi+1,p.se+1}] && indfuente[pii{p.fi-1,p.se+1}]){ u.push_back(indfuente[pii{p.fi+1,p.se+1}]-1); w.push_back(indfuente[pii{p.fi-1,p.se+1}]-1); a.push_back(p.fi); b.push_back(p.se); } else if (indfuente[pii{p.fi+1,p.se-1}] && indfuente[pii{p.fi-1,p.se-1}]){ u.push_back(indfuente[pii{p.fi+1,p.se-1}]-1); w.push_back(indfuente[pii{p.fi-1,p.se-1}]-1); a.push_back(p.fi); b.push_back(p.se); } } else{ if (indfuente[pii{p.fi+1,p.se+1}] && indfuente[pii{p.fi+1,p.se-1}]){ u.push_back(indfuente[pii{p.fi+1,p.se+1}]-1); w.push_back(indfuente[pii{p.fi+1,p.se-1}]-1); a.push_back(p.fi); b.push_back(p.se); } else if (indfuente[pii{p.fi-1,p.se+1}] && indfuente[pii{p.fi-1,p.se-1}]){ u.push_back(indfuente[pii{p.fi-1,p.se+1}]-1); w.push_back(indfuente[pii{p.fi-1,p.se-1}]-1); a.push_back(p.fi); b.push_back(p.se); } } } dsu comp(n); for (int i=0;i<u.size();i++) comp.unite(u[i],w[i]); for (int i=0;i<n;i++) if (comp.find(i)!=comp.find(0)) return 0; build(u,w,a,b); return 1; }

Compilation message (stderr)

parks.cpp: In function 'int construct_roads(std::vector<int>, std::vector<int>)':
parks.cpp:94:19: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   94 |     for (int i=0;i<u.size();i++) comp.unite(u[i],w[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...