제출 #441392

#제출 시각아이디문제언어결과실행 시간메모리
441392daniel920712분수 공원 (IOI21_parks)C++17
5 / 100
3562 ms67036 KiB
#include "parks.h" #include <map> #include <utility> #include <queue> using namespace std; map < pair < int , int > , int > all,con; map < pair < int , int > , pair < int , int > > road; vector < int > u,v,a,b; queue < pair < int , int > > BFS; int Father[200005]; int Find(int here) { if(Father[here]==here) return here; Father[here]=Find(Father[here]); return Father[here]; } int construct_roads(vector < int > x, vector < int > y) { int N=x.size(),i,t,aa,bb,ok=1,xx,yy,how=0; for(i=0;i<N;i++) { all[make_pair(x[i],y[i])]=i; Father[i]=i; } for(i=0;i<N;i++) { if(all.find(make_pair(x[i],y[i]+2))!=all.end()) { how++; t=all[make_pair(x[i],y[i]+2)]; road[make_pair(x[i],y[i]+1)]=make_pair(i,t); con[make_pair(x[i]+1,y[i]+1)]++; con[make_pair(x[i]-1,y[i]+1)]++; aa=Find(i); bb=Find(t); if(aa!=bb) Father[aa]=bb; } if(all.find(make_pair(x[i]+2,y[i]))!=all.end()) { how++; t=all[make_pair(x[i]+2,y[i])]; road[make_pair(x[i]+1,y[i])]=make_pair(i,t); con[make_pair(x[i]+1,y[i]+1)]++; con[make_pair(x[i]+1,y[i]-1)]++; aa=Find(i); bb=Find(t); if(aa!=bb) Father[aa]=bb; } } for(auto i:con) if(i.second==1) BFS.push(i.first); while(!BFS.empty()) { xx=BFS.front().first; yy=BFS.front().second; BFS.pop(); if(con[make_pair(xx,yy)]==0) continue; if(road.find(make_pair(xx+1,yy))!=road.end()) aa=xx+1,bb=yy; if(road.find(make_pair(xx-1,yy))!=road.end()) aa=xx-1,bb=yy; if(road.find(make_pair(xx,yy+1))!=road.end()) aa=xx,bb=yy+1; if(road.find(make_pair(xx,yy-1))!=road.end()) aa=xx,bb=yy-1; u.push_back(road[make_pair(aa,bb)].first); v.push_back(road[make_pair(aa,bb)].second); a.push_back(xx); b.push_back(yy); road.erase(make_pair(aa,bb)); if(aa%2==0) { con[make_pair(aa-1,bb)]--; con[make_pair(aa+1,bb)]--; if(con[make_pair(aa-1,bb)]==1) BFS.push(make_pair(aa-1,bb)); if(con[make_pair(aa+1,bb)]==1) BFS.push(make_pair(aa+1,bb)); } else { con[make_pair(aa,bb-1)]--; con[make_pair(aa,bb+1)]--; if(con[make_pair(aa,bb-1)]==1) BFS.push(make_pair(aa,bb-1)); if(con[make_pair(aa,bb+1)]==1) BFS.push(make_pair(aa,bb+1)); } } t=Find(0); for(i=0;i<N;i++) if(t!=Find(i)) ok=0; if(ok) { if(how!=N-1) while(1); } if(!road.empty()) ok=0; if(ok) build(u,v,a,b); return ok; }

컴파일 시 표준 에러 (stderr) 메시지

parks.cpp: In function 'int construct_roads(std::vector<int>, std::vector<int>)':
parks.cpp:79:32: warning: 'bb' may be used uninitialized in this function [-Wmaybe-uninitialized]
   79 |             con[make_pair(aa,bb+1)]--;
      |                              ~~^~
#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...