QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#606858 | #8941. Even or Odd Spanning Tree | lllei# | WA | 107ms | 3648kb | C++20 | 3.6kb | 2024-10-03 12:41:51 | 2024-10-03 12:41:54 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
using LL = long long;
struct DSU {
int n;
vector<int> fa;
DSU (int n) : n(n) {
fa.resize(n);
iota(fa.begin(), fa.end(), 0);
}
int find(int x) {
return (x == fa[x] ? x : fa[x] = find(fa[x]));
}
void merge(int x, int y) {
int fx = find(x);
int fy = find(y);
fa[fy] = fx;
}
bool same(int x, int y) {
return find(x) == find(y);
}
};
void solve() {
int n, m;
cin >> n >> m;
DSU dsu(n);
vector<vector<array<int, 2>>> e(n);
int cnt = 0;
vector<array<int, 3>> a;
LL sum = 0;
vector<array<int, 3>> ee(m);
for (int i = 0; i < m; ++i) {
int u, v, w;
cin >> u >> v >> w;
ee[i] = {w, u, v};
}
sort(ee.begin(), ee.end());
for (int i = 0; i < m; ++i) {
auto [z, x, y] = ee[i];
--x, --y;
if (dsu.same(x, y)) {
a.push_back({x, y, z});
continue;
}
e[x].push_back({y, z});
e[y].push_back({x, z});
dsu.merge(x, y);
++cnt;
sum += z;
}
if (cnt != n - 1) {
cout << -1 << ' ' << -1 << "\n";
return;
}
const int INF = 1e9 + 10;
const LL INF1 = 1e18 + 10;
const int N = __lg(n) + 1;
vector fa(N, vector<int>(n, -1));
vector val(2, vector(N, vector<int>(n, INF)));
vector<int> dep(n);
auto dfs = [&](auto &&self, int u) -> void {
for (auto [v, w]: e[u]) {
if (v == fa[0][u]) {
continue;
}
dep[v] = dep[u] + 1;
val[w & 1][0][v] = w;
fa[0][v] = u;
self(self, v);
}
};
dep[0] = 1;
dfs(dfs, 0);
for (int i = 1; i < N; ++i) {
for (int j = 0; j < n; ++j) {
fa[i][j] = fa[i - 1][fa[i - 1][j]];
val[0][i][j] = min(val[0][i - 1][j], val[0][i - 1][fa[i - 1][j]]);
val[1][i][j] = min(val[1][i - 1][j], val[1][i - 1][fa[i - 1][j]]);
}
}
LL sum1 = INF1;
for (auto [u, v, w] : a) {
int t = w & 1;
int tt = 1 - t;
if (dep[u] < dep[v]) {
swap(u, v);
}
int res = INF;
for (int i = N - 1; i >= 0; --i) {
if (fa[i][u] != -1 && dep[fa[i][u]] >= dep[v]) {
res = min(res, val[tt][i][u]);
u = fa[i][u];
}
}
if (u == v) {
if (res != INF) {
sum1 = min(sum1, sum - res + w);
}
continue;
}
for (int i = N - 1; i >= 0; --i) {
if (fa[i][u] != fa[i][v]) {
res = min({res, val[tt][i][u], val[tt][i][v]});
u = fa[i][u];
v = fa[i][v];
}
}
res = min({res, val[tt][0][u], val[tt][0][v]});
if (res != INF) {
sum1 = min(sum1, sum - res + w);
}
}
if (sum != INF1 && (sum % 2 == 0)) {
cout << sum << ' ';
} else if (sum1 != INF1 && (sum1 % 2 == 0)) {
cout << sum1 << ' ';
} else {
cout << -1 << ' ';
}
if (sum != INF1 && (sum % 2 == 1)) {
cout << sum << '\n';
} else if (sum1 != INF1 && (sum1 % 2 == 1)) {
cout << sum1 << '\n';
} else {
cout << -1 << '\n';
}
}
int main() {
cin.tie(0);
ios::sync_with_stdio(0);
int t;
cin >> t;
while (t--) {
solve();
}
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 1ms
memory: 3648kb
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
Wrong Answer
time: 107ms
memory: 3608kb
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:
3140067932 3159441841 1262790434 1332462897 1263932600 1395151561 1189242112 1180186165 2248358640 2277656157 3776889482 3738936375 1093500444 1058677117 3451376434 3402127725 1258609116 1187873655 1395482806 1411327105 3456885934 3486092007 3943951826 3988876469 2479987500 2752449745 2909126794 317...
result:
wrong answer 4th numbers differ - expected: '1309454727', found: '1332462897'