Submission #951652

# Submission time Handle Problem Language Result Execution time Memory
951652 2024-03-22T08:52:17 Z temmieowo Village (BOI20_village) C++14
31 / 100
700 ms 8796 KB
#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 = 100000+10;
const int INF = 2e18;

int n;
int a, b;
vector<vector<int>> G(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);

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].back()];
            mi_ans[G[now].back()] = now;
        }
        total += 2;
    }
    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
    cout << mi << " " << ma << "\n";
    for (int i=0 ; i<n ; i++){
        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 time Memory Grader output
1 Correct 3 ms 4188 KB Output is correct
2 Correct 2 ms 4380 KB Output is correct
3 Correct 2 ms 4188 KB Output is correct
4 Correct 2 ms 4184 KB Output is correct
5 Correct 2 ms 4188 KB Output is correct
6 Correct 2 ms 4188 KB Output is correct
7 Correct 2 ms 4184 KB Output is correct
8 Correct 2 ms 4188 KB Output is correct
9 Correct 2 ms 4188 KB Output is correct
10 Correct 2 ms 4188 KB Output is correct
11 Correct 1 ms 4188 KB Output is correct
12 Correct 2 ms 4188 KB Output is correct
13 Correct 3 ms 4188 KB Output is correct
14 Correct 2 ms 4188 KB Output is correct
15 Correct 1 ms 4188 KB Output is correct
16 Correct 2 ms 4188 KB Output is correct
17 Correct 2 ms 4184 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 2 ms 4188 KB Output is correct
2 Correct 3 ms 4188 KB Output is correct
3 Correct 3 ms 4188 KB Output is correct
4 Partially correct 7 ms 4184 KB Partially correct
5 Correct 7 ms 4188 KB Output is correct
6 Correct 6 ms 4184 KB Output is correct
7 Correct 7 ms 4444 KB Output is correct
8 Correct 6 ms 4188 KB Output is correct
9 Correct 5 ms 4188 KB Output is correct
10 Correct 6 ms 4444 KB Output is correct
11 Correct 5 ms 4440 KB Output is correct
12 Correct 5 ms 4188 KB Output is correct
13 Correct 6 ms 4188 KB Output is correct
14 Correct 6 ms 4188 KB Output is correct
15 Correct 5 ms 4188 KB Output is correct
16 Correct 6 ms 4188 KB Output is correct
17 Correct 5 ms 4188 KB Output is correct
18 Correct 5 ms 4188 KB Output is correct
19 Correct 5 ms 4188 KB Output is correct
20 Correct 5 ms 4188 KB Output is correct
21 Correct 5 ms 4188 KB Output is correct
22 Correct 6 ms 4184 KB Output is correct
23 Correct 6 ms 4424 KB Output is correct
24 Correct 5 ms 4188 KB Output is correct
25 Correct 3 ms 4188 KB Output is correct
26 Correct 7 ms 4188 KB Output is correct
27 Correct 3 ms 4188 KB Output is correct
28 Correct 6 ms 4188 KB Output is correct
29 Correct 8 ms 4444 KB Output is correct
30 Correct 6 ms 4444 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 3 ms 4188 KB Output is correct
2 Correct 2 ms 4380 KB Output is correct
3 Correct 2 ms 4188 KB Output is correct
4 Correct 2 ms 4184 KB Output is correct
5 Correct 2 ms 4188 KB Output is correct
6 Correct 2 ms 4188 KB Output is correct
7 Correct 2 ms 4184 KB Output is correct
8 Correct 2 ms 4188 KB Output is correct
9 Correct 2 ms 4188 KB Output is correct
10 Correct 2 ms 4188 KB Output is correct
11 Correct 1 ms 4188 KB Output is correct
12 Correct 2 ms 4188 KB Output is correct
13 Correct 3 ms 4188 KB Output is correct
14 Correct 2 ms 4188 KB Output is correct
15 Correct 1 ms 4188 KB Output is correct
16 Correct 2 ms 4188 KB Output is correct
17 Correct 2 ms 4184 KB Output is correct
18 Correct 2 ms 4188 KB Output is correct
19 Correct 3 ms 4188 KB Output is correct
20 Correct 3 ms 4188 KB Output is correct
21 Partially correct 7 ms 4184 KB Partially correct
22 Correct 7 ms 4188 KB Output is correct
23 Correct 6 ms 4184 KB Output is correct
24 Correct 7 ms 4444 KB Output is correct
25 Correct 6 ms 4188 KB Output is correct
26 Correct 5 ms 4188 KB Output is correct
27 Correct 6 ms 4444 KB Output is correct
28 Correct 5 ms 4440 KB Output is correct
29 Correct 5 ms 4188 KB Output is correct
30 Correct 6 ms 4188 KB Output is correct
31 Correct 6 ms 4188 KB Output is correct
32 Correct 5 ms 4188 KB Output is correct
33 Correct 6 ms 4188 KB Output is correct
34 Correct 5 ms 4188 KB Output is correct
35 Correct 5 ms 4188 KB Output is correct
36 Correct 5 ms 4188 KB Output is correct
37 Correct 5 ms 4188 KB Output is correct
38 Correct 5 ms 4188 KB Output is correct
39 Correct 6 ms 4184 KB Output is correct
40 Correct 6 ms 4424 KB Output is correct
41 Correct 5 ms 4188 KB Output is correct
42 Correct 3 ms 4188 KB Output is correct
43 Correct 7 ms 4188 KB Output is correct
44 Correct 3 ms 4188 KB Output is correct
45 Correct 6 ms 4188 KB Output is correct
46 Correct 8 ms 4444 KB Output is correct
47 Correct 6 ms 4444 KB Output is correct
48 Execution timed out 1041 ms 8796 KB Time limit exceeded
49 Halted 0 ms 0 KB -