QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#577900#8941. Even or Odd Spanning Treeskip2004WA 103ms5960kbC++202.8kb2024-09-20 15:20:162024-09-20 15:20:16

Judging History

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

  • [2024-09-20 15:20:16]
  • 评测
  • 测评结果:WA
  • 用时:103ms
  • 内存:5960kb
  • [2024-09-20 15:20:16]
  • 提交

answer

#include<bits/stdc++.h>
namespace rgs = std::ranges;
using std::cin, std::cout;
using ll = long long;
using u64 = unsigned long long;
using db = double;
int T;


const int N = 200005;
struct edge {
	int u, v, w;
};
int n, m;
int anc[N];
int find(int x) {
	return anc[x] == x ? x : anc[x] = find(anc[x]);
}
std::vector<std::pair<int, int>> e[N];

int max[N][20][2];
int jump[N][20];
int dep[N];


const int inf = 1e9 + 10;
void dfs0(int x, int fa = 0) {
	dep[x] = dep[fa] + 1;
	for(int i = 1;i < 20;++i) {
		max[x][i][0] = std::max(max[x][i][0], max[jump[x][i - 1]][i][0]);
		max[x][i][1] = std::max(max[x][i][1], max[jump[x][i - 1]][i][1]);
		jump[x][i] = jump[jump[x][i - 1]][i - 1];
	}
	for(auto [i, w] : e[x]) if(i != fa) {
		max[i][0][0] = -inf;
		max[i][0][1] = -inf;
		max[i][0][w & 1] = w;
		jump[i][0] = x;
		dfs0(i, x);
	}
}
void up(int & x, int y) {
	if(x < y) x = y;
}
std::array<int, 2> query(int u, int v) {
	std::array<int, 2> ans{-inf, -inf};
	if(dep[u] > dep[v]) std::swap(u, v);
	for(int t = dep[v] - dep[u];t;t &= t - 1) {
		up(ans[0], max[v][__builtin_ctz(t)][0]);
		up(ans[1], max[v][__builtin_ctz(t)][1]);
		v = jump[v][__builtin_ctz(t)];
	}
	for(int i = 19;i >= 0;--i) {
		if(jump[u][i] != jump[v][i]) {
			up(ans[0], max[u][i][0]);
			up(ans[0], max[v][i][0]);
			up(ans[1], max[u][i][1]);
			up(ans[1], max[v][i][1]);
			u = jump[u][i];
			v = jump[v][i];
		}
	}
	if(u != v) {
		up(ans[0], max[u][0][0]);
		up(ans[0], max[v][0][0]);
		up(ans[1], max[u][0][1]);
		up(ans[1], max[v][0][1]);
	}
	return ans;
}

void solve() {
	cin >> n >> m;
	std::vector<edge> v;
	for(int i = 0, u, vv, w;i < m;++i) {
		cin >> u >> vv >> w;
		v.push_back({u, vv, w});
	}
	sort(v.begin(), v.end(), [](edge x, edge y) { return x.w < y.w; });
	for(int i = 1;i <= n;++i) {
		anc[i] = i;
	}
	int cc = 0;
	ll sum = 0;
	for(auto [u, v, w] : v) {
		if(find(u) != find(v)) {
			cc += 1;
			anc[find(u)] = find(v);
			e[u].emplace_back(v, w);
			e[v].emplace_back(u, w);
			sum += w;
		}
	}
	if(cc != n - 1) {
		cout << -1 << ' ' << -1 << '\n';
		return ;
	}
	dfs0(1);
	ll s2 = (ll) inf * inf;
	for(auto [u, v, w] : v) {
		auto res = query(u, v);
		if(res[w % 2 ^ 1] >= 0) {
			s2 = std::min(s2, sum + w - res[w % 2 ^ 1]);
		}
	}
	if(s2 == (ll) inf * inf) {
		s2 = -1;
	}
	if(sum % 2 == 1) {
		std::swap(sum, s2);
	}
	cout << sum << ' ' << s2 << '\n';
}
void clear() {
	memset(jump, 0, sizeof(jump[0]) * (n + 1));
	memset(max, 0, sizeof(max[0]) * (n + 1));
	memset(anc, 0, sizeof(anc[0]) * (n + 1));
	memset(dep, 0, sizeof(dep[0]) * (n + 1));
	memset(anc, 0, sizeof(anc[0]) * (n + 1));
	for(int i = 1;i <= n;++i) e[i].clear();
}
int main() {
	std::ios::sync_with_stdio(false), cin.tie(0);
	cin >> T;
	for(int i = 0;i < T;++i) {
		solve();
		clear();
	}
}

详细

Test #1:

score: 100
Accepted
time: 1ms
memory: 3912kb

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: 103ms
memory: 5960kb

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 1309454727
1263932600 1565384431
1189242112 1180186165
2248358640 2261370885
3883974152 3738936375
1116515874 1058677117
3433711014 3402127725
1228634386 1187873655
1395482806 1410162043
3456885934 3486092007
3943951826 3988876469
2479987500 2752449745
2909126794 293...

result:

wrong answer 6th numbers differ - expected: '1307926149', found: '1565384431'