QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#563931 | #8941. Even or Odd Spanning Tree | ucup-team3691# | WA | 132ms | 3708kb | C++14 | 5.0kb | 2024-09-14 17:28:03 | 2024-09-14 17:28:04 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
using namespace chrono;
using ll = long long;
using ull = unsigned long long;
string to_string(const string &s) {
return '"' + s + '"';
}
string to_string(bool b) {
return b ? "true" : "false";
}
template <typename A, typename B>
string to_string(const pair<A, B> &p) {
return "(" + to_string(p.first) + ", " + to_string(p.second) + ")";
}
template <typename T>
string to_string(const T &v) {
string s = "{";
bool first = true;
for (const auto &it : v) {
if (!first)
s += ", ";
else
first = false;
s += to_string(it);
}
return s += "}";
}
void debug_out() {
cerr << endl;
}
template <typename T, typename... Args>
void debug_out(const T &first, const Args&... rest) {
cerr << to_string(first) << " ";
debug_out(rest...);
}
#define debug(...) cerr << "[" << #__VA_ARGS__ << "]:", debug_out(__VA_ARGS__)
mt19937 rng(chrono::steady_clock::now().time_since_epoch().count());
auto startTime = high_resolution_clock::now();
int get_time() {
auto stopTime = chrono::high_resolution_clock::now();
auto duration = duration_cast<milliseconds>(stopTime - startTime);
return duration.count(); // in ms
}
struct dsu {
dsu(int n) : tt(n + 1), sz(n + 1) {
for (int i = 1; i <= n; ++i) {
tt[i] = i;
sz[i] = 1;
}
}
int find(int x) {
if (x == tt[x])
return x;
return tt[x] = find(tt[x]);
}
void unite(int x, int y) {
x = find(x);
y = find(y);
if (sz[x] < sz[y]) {
swap(x, y);
}
tt[y] = x;
sz[x] += sz[y];
}
vector<int> tt, sz;
};
struct edge {
int x, y, c;
bool operator < (const edge &aux) const {
return c < aux.c;
}
};
struct bin_info {
bin_info() : cp(-1), ci(-1) {}
bin_info(ll x) {
cp = ci = -1;
if (x % 2 == 0) {
cp = x;
} else {
ci = x;
}
}
ll cp, ci;
};
bin_info max(const bin_info& x, const bin_info &y) {
bin_info ret = x;
ret.cp = max(ret.cp, y.cp);
ret.ci = max(ret.ci, y.ci);
return ret;
}
bin_info min(const bin_info& x, const bin_info &y) {
bin_info ret = x;
if (ret.cp == -1)
ret.cp = y.cp;
else if (ret.cp != -1)
ret.cp = min(ret.cp, y.cp);
if (ret.ci == -1)
ret.ci = y.ci;
else if (y.ci != -1)
ret.ci = min(ret.ci, y.ci);
return ret;
}
struct arb {
arb(int n) : n(n), v(n + 1), tt(n + 1), c(n + 1), h(n + 1, 0) {
}
void add_edge(edge &it) {
v[it.x].push_back({it.y, it.c});
v[it.y].push_back({it.x, it.c});
}
void dfs(int nod, int papa = 0) {
for (auto it : v[nod]) {
if (it.first == papa)
continue;
h[it.first] = h[nod] + 1;
c[it.first] = it.second;
dfs(it.first, nod);
}
}
void build() {
bl.resize(k);
bt.resize(k);
for (int i = 0; i < k; ++i) {
bl[i].resize(n + 1);
bt[i].resize(n + 1);
}
for (int i = 1; i <= n; ++i) {
bt[0][i] = tt[i];
bl[0][i] = bin_info(c[i]);
}
for (int j = 1; j < k; ++j) {
for (int i = 1; i <= n; ++i) {
bt[j][i] = bt[j - 1][bt[j - 1][i]];
bl[j][i] = max(bl[j - 1][i], bl[j - 1][bt[j - 1][i]]);
}
}
}
bin_info lca(int x, int y) {
if (h[x] < h[y])
swap(x, y);
int dif = h[x];
bin_info ans(-1);
for (int j = 0; j < k && dif; ++j) {
if ((1 << j) & dif) {
ans = max(ans, bl[j][x]);
x = bt[j][x];
dif ^= (1 << j);
}
}
for (int j = k - 1; j >= 0; --j) {
if (bt[j][x] != bt[j][y]) {
ans = max(ans, bl[j][x]);
x = bt[j][x];
ans = max(ans, bl[j][y]);
y = bt[j][y];
}
}
ans = max(ans, bl[0][x]);
ans = max(ans, bl[0][y]);
return ans;
}
const int k = 20;
int n;
vector<vector<pair<int, int>>> v;
vector<int> tt;
vector<int> c;
vector<int> h;
vector<vector<bin_info>> bl;
vector<vector<int>> bt;
};
void solve() {
int n, m;
cin >> n >> m;
vector<edge> e(m);
for (auto& it : e) {
cin >> it.x >> it.y >> it.c;
}
sort(e.begin(), e.end());
dsu D(n);
arb A(n);
ll ans = 0;
for (auto it : e) {
if (D.find(it.x) != D.find(it.y)) {
D.unite(it.x, it.y);
ans += it.c;
A.add_edge(it);
}
}
for (int i = 2; i <= n; ++i) {
if (D.find(i) != D.find(1)) {
cout << "-1 -1\n";
return;
}
}
A.dfs(1);
A.build();
bin_info fin(ans);
for (auto it : e) {
auto q = A.lca(it.x, it.y);
if (q.cp != -1) {
fin = min(fin, bin_info(ans - q.cp + it.c));
}
if (q.ci != -1) {
fin = min(fin, bin_info(ans - q.ci + it.c));
}
}
cout << fin.cp << " " << fin.ci << "\n";
}
int main() {
cin.tie(NULL);
ios_base::sync_with_stdio(false);
int t = 1;
cin >> t;
while (t--)
solve();
return 0;
}
详细
Test #1:
score: 100
Accepted
time: 0ms
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: 132ms
memory: 3708kb
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:
4038579336 2835987235 -1 1248113103 -1 1086244513 -1 1180186165 2780727848 2106419765 -1 3540860661 2016387508 993168979 -1 3209485385 2054754068 1187873655 -1 1198884855 4344962916 3418251633 -1 3643734595 -1 2227345937 -1 2649718111 3337865622 2303539095 -1 1588809485 4519701990 3594994347 1417532...
result:
wrong answer 1st numbers differ - expected: '3140067932', found: '4038579336'