제출 #86823

#제출 시각아이디문제언어결과실행 시간메모리
86823gs14004Teoretičar (COCI18_teoreticar)C++17
130 / 130
7238 ms191060 KiB
#include <bits/stdc++.h> using namespace std; typedef long long lint; typedef long double llf; typedef pair<int, int> pi; const int MAXN = 500005; int deg[MAXN], rem[MAXN], ptr[MAXN]; vector<pi> gph[MAXN]; int n, m, cnt, ret[MAXN]; pi a[MAXN]; void flush(vector<int> &V, vector<int> &E){ for(auto &i : V){ deg[i] = ptr[i] = 0; gph[i].clear(); } for(auto &i : E) rem[i] = 0; } void dfs(int x, int c, vector<int> &l, vector<int> &r){ while(ptr[x] < gph[x].size()){ auto e = gph[x][ptr[x]]; ptr[x]++; if(!rem[e.first]){ rem[e.first] = 1; if(c & 1) r.push_back(e.first); else l.push_back(e.first); deg[a[e.first].first]--; deg[a[e.first].second]--; dfs(e.second, c + 1, l, r); break; } } } void assign(vector<int> edges){ bool not_base = 0; vector<int> vlist; for(auto &i : edges){ int s = a[i].first; int e = a[i].second; if(!deg[s]) vlist.push_back(s); deg[s]++; if(!deg[e]) vlist.push_back(e); deg[e]++; if(deg[s] > 1 || deg[e] > 1) not_base = 1; gph[s].emplace_back(i, e); gph[e].emplace_back(i, s); } if(!not_base){ cnt++; for(auto &i : edges) ret[i] = cnt; flush(vlist, edges); return; } vector<int> l, r; for(auto &i : vlist){ if(deg[i] & 1){ dfs(i, 0, l, r); } } for(auto &i : vlist){ while(deg[i]){ dfs(i, 0, l, r); } } flush(vlist, edges); assign(l); assign(r); } int main(){ int k; scanf("%d %d %d",&n,&k,&m); vector<int> v; for(int i=0; i<m; i++){ scanf("%d %d",&a[i].first,&a[i].second); a[i].second += n; v.push_back(i); } assign(v); printf("%d\n", cnt); for(int i=0; i<m; i++){ printf("%d\n", ret[i]); } }

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

teoreticar.cpp: In function 'void dfs(int, int, std::vector<int>&, std::vector<int>&)':
teoreticar.cpp:23:15: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  while(ptr[x] < gph[x].size()){
        ~~~~~~~^~~~~~~~~~~~~~~
teoreticar.cpp: In function 'int main()':
teoreticar.cpp:76:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  scanf("%d %d %d",&n,&k,&m);
  ~~~~~^~~~~~~~~~~~~~~~~~~~~
teoreticar.cpp:79:8: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   scanf("%d %d",&a[i].first,&a[i].second);
   ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...