QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#630678#8941. Even or Odd Spanning TreeyanchengzhiML 0ms13900kbC++203.4kb2024-10-11 19:56:222024-10-11 19:56:24

Judging History

你现在查看的是最新测评结果

  • [2024-10-11 19:56:24]
  • 评测
  • 测评结果:ML
  • 用时:0ms
  • 内存:13900kb
  • [2024-10-11 19:56:22]
  • 提交

answer

#include <bits/stdc++.h>
typedef long long ll;
using namespace std;
const int maxn = 2e5 + 5;
const int maxm = 5e5 + 5;
const int maxlog = 17;
int n, m, flag, pa[maxn], val[maxn], f[2][maxn][maxlog + 1], fa[maxn][maxlog + 1], dep[maxn];
bool vis[maxm];
ll ans[2];
vector<pair<int, int>> g[maxn];
struct edge {
    int u, v, w;
} e[maxm];
int find(int x) {
    return (pa[x] == x) ? x : (pa[x] = find(pa[x]));
}
void dfs_pre(int u, int from) {
    dep[u] = dep[from] + 1;
    if(u != 1) {
        int o = val[u] & 1;
        f[o][u][0] = val[u];
        f[o ^ 1][u][0] = 0;
        fa[u][0] = from;
        for(int i = 1; i <= maxlog; i++) {
            f[0][u][i] = max(f[0][u][i - 1], f[0][fa[u][i - 1]][i - 1]);
            f[1][u][i] = max(f[1][u][i - 1], f[1][fa[u][i - 1]][i - 1]);
            fa[u][i] = fa[fa[u][i - 1]][i - 1];
        }
    }
    for(auto i : g[u]) {
        int v = i.first, w = i.second;
        if(v == from) {
            continue;
        }
        val[v] = w;
        dfs_pre(v, u);
    }
}
int LCA(int x, int y) {
    if(dep[y] > dep[x]) {
        swap(x, y);
    }
    for(int i = maxlog; i >= 0; i--) {
        if(dep[fa[x][i]] >= dep[y]) {
            x = fa[x][i];
        }
    }
    if(x == y) {
        return x;
    }
    for(int i = maxlog; i >= 0; i--) {
        if(fa[x][i] != fa[y][i]) {
            x = fa[x][i];
            y = fa[y][i];
        }
    }
    return fa[x][0];
}
void work(){
    cin >> n >> m;
    for(int i = 1; i <= m; i++) {
        cin >> e[i].u >> e[i].v >> e[i].w;
    }
    sort(e + 1, e + 1 + m, [&](const edge &x, const edge &y) {
        return x.w < y.w;
    });
    ans[0] = ans[1] = flag = -1;
    for(int i = 1; i <= n; i++) {
        pa[i] = i;
        vis[i] = 0;
        g[i].clear();
    }
    ll res = 0;
    int cnt = 0;
    for(int i = 1; i <= m; i++) {
        if(find(e[i].u) != find(e[i].v)) {
            res += e[i].w;
            pa[find(e[i].u)] = find(e[i].v);
            cnt++;
            vis[i] = 1;
        }
    }
    if(cnt < n - 1) {
        cout << -1 << ' ' << -1 << '\n';
        return;
    }
    flag = (res & 1) ^ 1;
    ans[flag ^ 1] = res;
    for(int i = 1; i <= m; i++) {
        if(vis[i]) {
            int u = e[i].u, v = e[i].v, w = e[i].w;
            g[u].emplace_back(v, w);
            g[v].emplace_back(u, w);
        }
    }
    dfs_pre(1, 0);
    for(int i = 1; i <= m; i++) {
        if(vis[i]) {
            continue;
        }
        int u = e[i].u, v = e[i].v, w = e[i].w;
        int lca = LCA(u, v), mx = 0, o = (w & 1) ^ 1;
        for(int i = maxlog; i >= 0; i--) {
            if(fa[u][i] && dep[fa[u][i]] >= dep[lca]) {
                mx = max(mx, f[o][u][i]);
                u = fa[u][i];
            }
            if(fa[v][i] && dep[fa[v][i]] >= dep[lca]) {
                mx = max(mx, f[o][v][i]);
                v = fa[v][i];
            }
        }
        if(mx > 0) {
            if(ans[flag] == -1) {
                ans[flag] = ans[flag ^ 1] - mx + w;
            }
            else {
                ans[flag] = min(ans[flag], ans[flag ^ 1] - mx + w);
            }
        }
    }
    cout << ans[0] << ' ' << ans[1] << '\n';
}
int main(){
    ios::sync_with_stdio(false);
    cin.tie(0);
    int T;
    cin >> T;
    while(T--){
        work();
    }    
    return 0;
}

詳細信息

Test #1:

score: 100
Accepted
time: 0ms
memory: 13900kb

input:

3
2 1
1 2 5
3 1
1 3 1
4 4
1 2 1
1 3 1
1 4 1
2 4 2

output:

-1 5
-1 -1
4 3

result:

ok 6 numbers

Test #2:

score: -100
Memory Limit Exceeded

input:

10000
16 50
1 2 649251632
2 3 605963017
3 4 897721528
4 5 82446151
5 6 917109168
6 7 79647183
7 8 278566178
7 9 573504723
3 10 679859251
8 11 563113083
1 12 843328546
10 13 594049160
11 14 997882839
7 15 569431750
2 16 244494799
16 7 960172373
13 4 317888322
13 3 446883598
9 3 678142319
5 8 43208692...

output:


result: