QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#606952#8941. Even or Odd Spanning Treexing4c#WA 90ms30704kbC++144.7kb2024-10-03 13:12:042024-10-03 13:12:05

Judging History

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

  • [2024-10-03 13:12:05]
  • 评测
  • 测评结果:WA
  • 用时:90ms
  • 内存:30704kb
  • [2024-10-03 13:12:04]
  • 提交

answer

#include <bits/stdc++.h>
#define NOSYNC ios::sync_with_stdio(false); cin.tie(0); cout.tie(0)
#define all(x) x.begin(), x.end()
#define endl '\n'
#define INF LLONG_MAX
#define int ll
using namespace std;
using ll = long long;
using ull = unsigned long long;

const int N = 200005;
const int M = 500005;
const int S = 21;
// -------------- Templates Above -------------------------
int n, m;
struct node {
	int v, w;
};
struct edge {
	int u, v, w, id;
	bool operator < (const edge &o) const {
		return w < o.w;
	}
};
edge e[M];
vector<node> g[N];
int ans[2];
// -----------------------------------------------
int dad[N]; int choose[M]; // 记录选择的边
int getfa(int x) {
	if(dad[x] == x) return x;
	return dad[x] = getfa(dad[x]);
}
bool ask(int x, int y) {
	int fx = getfa(x);
	int fy = getfa(y);
	if(fx == fy) return 1;
	return 0;
}
void merge(int x, int y) {
	if(!ask(x, y)) dad[getfa(x)] = getfa(y);
}
int kruskal() {
	for(int i = 1; i <= n; i ++) dad[i] = i;
	int cnt = 0; int ans = 0;
	sort(e+1, e+1+m);
	for(int i = 1; i <= m; i ++) {
		if(!ask(e[i].u, e[i].v)) {
			ans += e[i].w;
			cnt ++;
			merge(e[i].u, e[i].v);
			choose[e[i].id] = 1;
		}
		if(cnt == n-1) break;
	}
	if(cnt < n-1) return -1;
	return ans;
}
// -----------------------------------------------
int hson[N], dep[N], siz[N], fa[N];
int top[N], id[N], rnk[N], dfncnt;
int pval[N];
int st[2][N][22];
int logn[N];

void build() {
	for(int i = 1; i <= n; i ++) {
		int val = pval[rnk[i]];
		if(val & 1) {
			st[1][i][0] = val;
			st[0][i][0] = INF;	
		}
		else {
			st[0][i][0] = val;
			st[1][i][0] = INF;	
		}
	}
	for(int j = 1; j <= S; j ++) {
		for(int i = 1; i + (1 << j) - 1 <= n; i ++) {
			st[0][i][j] = max(st[0][i][j], st[0][i + (1 << (j-1))][j-1]);
			st[1][i][j] = max(st[1][i][j], st[1][i + (1 << (j-1))][j-1]);
		} 
	}
}
int rangeQmax(int which, int l, int r) {
	int s = logn[r - l + 1];
	return max(st[which][l][s], st[which][r - (1 << s) + 1][s]);
}

void dfs1(int x) {
	hson[x] = -1;
	siz[x] = 1;
	for(auto [y, w] : g[x]) {
		if(dep[y]) continue;
		fa[y] = x;
		dep[y] = dep[x] + 1;
		pval[y] = w;
		dfs1(y);
		siz[x] += siz[y];
		if(hson[x] == -1 || siz[y] > siz[hson[x]]) hson[x] = y;
	}
}
void dfs2(int x, int t) {
	top[x] = t;
	id[x] = ++dfncnt;
	rnk[dfncnt] = x;
	if(hson[x] != -1) dfs2(hson[x], t);
	for(auto [y, w] : g[x]) {
		if(y != fa[x] && y != hson[x]) dfs2(y, y);
 	}
}
int pathQmax(int which, int x, int y) {
	int res = -1;
	while(top[x] != top[y]) {
		if(dep[top[x]] < dep[top[y]]) swap(x, y);
		res = max(res, rangeQmax(which, id[top[x]], id[x]));
		x = fa[top[x]];
	}
	if(dep[x] > dep[y]) swap(x, y);
	if(x != y) res = max(res, rangeQmax(which, id[x]+1, id[y]));
	return res;
}
// -----------------------------------------------
void clear() {
	for(int i = 1; i <= n; i ++) {
		st[0][i][0] = 0;
		st[1][i][0] = 0;
	}
	for(int j = 1; j <= S; j ++) {
		for(int i = 1; i + (1 << j) - 1 <= n; i ++) {
			st[0][i][j] = 0;
			st[1][i][j] = 0;
		} 
	}
	for(int i = 1; i <= m; i ++) {
		e[i] = {0, 0, 0, 0};
	}
	for(int i = 1; i <= n; i ++) {
		g[i].clear();
	}
	for(int i = 1; i <= n; i ++) {
		hson[i] = siz[i] = dep[i] = fa[i] = 0;
		top[i] = id[i] = rnk[i] = 0; dfncnt = 0;
		pval[i] = 0;
	}
	for(int i = 1; i <= n; i ++) {
		dad[i] = 0;
	}
	for(int i = 1; i <= m; i ++) {
		choose[i] = 0;
	}
	ans[0] = ans[1] = 0;
}

void solve() {
	cin >> n >> m;
	for(int i = 1; i <= m; i ++) {
		int u, v, w;
		cin >> u >> v >> w;
		e[i] = {u, v, w, i};
		// G[u].push_back({v, w});
	}
	int res = kruskal(); 
	
	if(res == -1) {
		cout << -1 << " " << -1 << endl;
		clear();
		return;
	}
	
	
	ans[res&1] = res; // 求出其中一个答案
	ans[(res&1)^1] = INF;
	for(int i = 1; i <= m; i ++) {
		if(choose[e[i].id]) {
			auto [u, v, w, id] = e[i];
			g[u].push_back({v, w});
			g[v].push_back({u, w});
		}
	}
	dep[1] = 1;
	dfs1(1);
	dfs2(1, 1);
	build();
	for(int i = 1; i <= m; i ++) {
		if(choose[e[i].id]) continue;
		auto [u, v, w, id] = e[i];
		int which;
		if(w & 1) which = 0;
		else which = 1;
		// --------------------
		int mx = pathQmax(which, u, v);
		if(mx == INF || mx == -1) continue;
		ans[(res&1)^1] = min(ans[(res&1)^1], res - mx + w);
	}
	for(int i = 0; i <= 1; i ++) {
		if(ans[i] == INF) cout << -1 << " ";
		else cout << ans[i] << " ";
	}
	cout << endl;
	clear();
}
// -----------------------------------------------
signed main() {
	NOSYNC;
	logn[1] = 0;
	logn[2] = 1;
	for(int i = 3; i < N; i ++) {
		logn[i] = logn[i/2] + 1;
	}
	int t; cin >> t;
	for(int i = 1; i <= t; i ++) {
		// cout << "Case #" << i << ":" << endl;
		solve();
	}
	return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 3ms
memory: 29128kb

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: 90ms
memory: 30704kb

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 3416475051 
1262790434 1309454727 
1263932600 1333657263 
1189242112 1180186165 
2248358640 2277656157 
3799472702 3738936375 
1207733704 1058677117 
3433711014 3402127725 
1201099898 1187873655 
1395482806 1440596255 
3456885934 3486092007 
3943951826 4005009799 
2479987500 2733678685 
2...

result:

wrong answer 2nd numbers differ - expected: '3159441841', found: '3416475051'