Submission #22982

#TimeUsernameProblemLanguageResultExecution timeMemory
22982model_codeNetwork (BOI15_net)C++11
100 / 100
819 ms63228 KiB
/*/ Task: net Model solution Author: Bartosz Kostka /*/ #include "bits/stdc++.h" using namespace std; const int MAXN = 500007; bool odw[MAXN]; int leaves[MAXN]; int numleaves; vector <int> G[MAXN], S[MAXN]; void dfs(int v) { odw[v] = true; if((int)G[v].size() == 1) leaves[v] = 1; for(auto w : G[v]) if(odw[w]==false) { dfs(w); leaves[v] += leaves[w]; } } int findcut(int v) { odw[v] = true; for(auto w : G[v]) if(odw[w] == false) if(leaves[w] > numleaves/2) return findcut(w); return v; } void newdfs(int v, int tree) { //cerr << v << " " << tree << "T\n"; odw[v] = true; if((int)G[v].size() == 1) S[tree].push_back(v); for(auto w : G[v]) if(odw[w] == false) newdfs(w,tree); } int subtree; int cut(int n) { dfs(1); for(int i=1; i<=n; i++) odw[i] = false; int w = findcut(1); for(int i=1; i<=n; i++) odw[i] = false; odw[w] = true; for(auto v : G[w]) newdfs(v,++subtree); return w; } vector <int> W; int next(int e, int nn) { e += 2; if(e==nn) e = 1; return e; } int main() { int n; scanf("%d", &n); if(n==1) { printf("0\n"); return 0; } if(n==2) { printf("1\n1 2\n"); return 0; } for(int i=1; i<n; i++) { int a, b; scanf("%d%d", &a, &b); G[a].push_back(b); G[b].push_back(a); } for(int i=1; i<=n; i++) if((int)G[i].size() == 1) numleaves++; int res = (numleaves+1)/2; printf("%d\n", res); cut(n); W.resize(2*res); int e = 0; for(int i=1; i<=subtree; i++) { for(auto ele : S[i]) { W[e] = ele; e = next(e,2*res); //cerr << ele << "." << e << "\n"; } } if((!W.empty()) and W.back() == 0) W.back() = S[1][0]; for(int i=0; i<(int)W.size(); i+=2) printf("%d %d\n", W[i], W[i+1]); }

Compilation message (stderr)

net.cpp: In function 'int main()':
net.cpp:82:18: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   scanf("%d", &n);
                  ^
net.cpp:96:26: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
     scanf("%d%d", &a, &b);
                          ^
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...