제출 #1356726

#제출 시각아이디문제언어결과실행 시간메모리
1356726vjudge1Village (BOI20_village)C++17
50 / 100
43 ms15128 KiB
#include <bits/stdc++.h>
using namespace std;

#define int long long

int ans = 0;
vector<int> gp(200005, 0);
vector<int> cp;
void dfs(vector<int> ap[], int cur, int par) {
    for (auto& p : ap[cur]) {
        if (p == par) continue;
        dfs(ap, p, cur);
        if (!gp[p] && !gp[cur]) ans += 2, gp[cur] = 1, gp[p] = 1, swap(cp[cur], cp[p]);
    }
}
void dfs2(vector<int> ap[], int cur, int par) {
    for (auto& p : ap[cur]) {
        if (p == par) continue;
        dfs2(ap, p, cur);
        if (!gp[p] || !gp[cur]) ans += 2, gp[cur] = 1, gp[p] = 1, swap(cp[cur], cp[p]); 
    }
}

signed main()
{
    ios_base::sync_with_stdio(false);
    cin.tie(0);
    
    int n;
    cin >> n;

    vector<int> ap[n + 1];
    for (int i = 0; i < n - 1; i++) {
        int u, v;
        cin >> u >> v;
        ap[u].push_back(v);
        ap[v].push_back(u);
    }
    for (int i = 0; i <= n; i++) {
        cp.push_back(i);
    }
    dfs(ap, 1, -1);
    dfs2(ap, 1, -1);

    cout << ans << ' ' << 1 << '\n';
    for (int i = 1; i <= n; i++) cout << cp[i] << ' ';
    for (int i = 1; i <= n; i++) cout << 1 << ' ';

    return 0;
}

/*


*/
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...