Submission #951631

#TimeUsernameProblemLanguageResultExecution timeMemory
951631temmieowoVillage (BOI20_village)C++17
31 / 100
15 ms16988 KiB
#include <bits/stdc++.h> #define int long long #define fastio ios::sync_with_stdio(0), cin.tie(0); using namespace std; const int MAX_N = 1000+10; const int INF = 2e18; int n; int a, b; vector<vector<int>> G(MAX_N); vector<vector<int>> dis(MAX_N, vector<int>(MAX_N)); bitset<MAX_N> vis; int total = 0; int ma = -INF, mi = INF; vector<int> ma_ans(MAX_N, -1), mi_ans(MAX_N, -1); void dfs(int start, int now, int pre){ if (pre!=-1) dis[start][now] = dis[start][pre]+1; for (auto x : G[now]){ if (x!=pre){ dfs(start, x, now); } } return; } pair<int, int> dfs2(int now, int pre){ // <最遠點距離, 最遠點> pair<int, int> ret = {0, now}; for (auto x : G[now]){ if (x!=pre && vis[x]==0){ pair<int, int> res = dfs2(x, now); ret = max(ret, res); } } ret.first++; return ret; } void dfs3(int now, int pre){ // cerr << now << endl; for (auto x : G[now]){ if (x!=pre){ dfs3(x, now); } } if (mi_ans[now]==-1){ if (pre!=-1){ mi_ans[now] = (mi_ans[pre]==-1 ? pre : mi_ans[pre]); mi_ans[pre] = now; }else{ mi_ans[now] = mi_ans[G[now].front()]; mi_ans[G[now].front()] = now; } total += 2; } return; } void solve1(){ // input cin >> n; for (int i=0 ; i<n-1 ; i++){ cin >> a >> b; a--, b--; G[a].push_back(b); G[b].push_back(a); } // init vector<int> v; for (int i=0 ; i<n ; i++){ v.push_back(i); dfs(i, i, -1); } // for (int i=0 ; i<n ; i++){ // for (int j=0 ; j<n ; j++){ // cerr << dis[i][j] << " "; // } // cerr << "\n"; // } // return; // process int ma = -INF, mi = INF; vector<int> ma_ans, mi_ans; do{ int total = 0; for (int i=0 ; i<n ; i++){ if (i==v[i]) goto flag; total += dis[i][v[i]]; } if (total>ma){ ma = total; ma_ans = v; } if (total<mi){ mi = total; mi_ans = v; } flag:; } while (next_permutation(v.begin(), v.end())); cout << mi << " " << ma << "\n"; for (auto x : mi_ans){ cout << x+1 << " "; } cout << "\n"; for (auto x : ma_ans){ cout << x+1 << " "; } cout << "\n"; return; } void solve2(){ // input cin >> n; for (int i=0 ; i<n-1 ; i++){ cin >> a >> b; a--, b--; G[a].push_back(b); G[b].push_back(a); } // 找到最長的方式 total = 0; pair<int, int> aa, bb; for (int i=0 ; i<n/2 ; i++){ for (int j=0 ; j<n ; j++){ if (vis[j]==0){ aa = dfs2(j, -1); bb = dfs2(aa.second, -1); vis[aa.second] = 1; vis[bb.second] = 1; total += (bb.first-1)*2; // cerr << "樹直徑:" << aa.second+1 << " & " << bb.second+1 << " 貢獻:" << (bb.first-1)*2 << endl; ma_ans[aa.second] = bb.second; ma_ans[bb.second] = aa.second; break; } } } if (n%2==1){ for (int i=0 ; i<n ; i++){ if (ma_ans[i]==-1){ ma_ans[i] = ma_ans[aa.second]; ma_ans[aa.second] = i; } } } ma = total; // 找到最短的方法 total = 0; dfs3(0, -1); mi = total; // output vis = 0; cout << mi << " " << ma << "\n"; for (int i=0 ; i<n ; i++){ assert(vis[mi_ans[i]]==0); assert(i!=mi_ans[i]); vis[mi_ans[i]] = 1; cout << mi_ans[i]+1 << " "; } cout << "\n"; for (int i=0 ; i<n ; i++){ cout << ma_ans[i]+1 << " "; } cout << "\n"; return; } signed main(){ fastio; int t = 1; while (t--){ solve2(); } return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...