QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#605124#8941. Even or Odd Spanning Treeucup-team4352#WA 281ms86508kbC++232.9kb2024-10-02 15:38:202024-10-02 15:38:21

Judging History

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

  • [2024-10-02 15:38:21]
  • 评测
  • 测评结果:WA
  • 用时:281ms
  • 内存:86508kb
  • [2024-10-02 15:38:20]
  • 提交

answer

#include <bits/stdc++.h>
using namespace std;
const int maxn=2e5+5,maxm=5e5+5;
typedef long long ll;
int logg[maxn];
void Init() {
	logg[0]=-1;
	int N=2e5;
	for(int i=1;i<=N;++i) logg[i]=logg[i/2]+1;
}
ll ans,tmp;
int T,n,m;
int f[maxn];
int find(int x) {
	return x==f[x]?x:f[x]=find(f[x]);
}
struct Data{
	int x,y,z;
}a[maxm];
bool comp(Data A,Data B) {
	return A.z<B.z;
}
int Max[2][maxn][20],nxt[maxn][20];
vector<int>qwq[maxn],w[maxn];
int wp[maxn],top[maxn],dep[maxn];
bool vis[maxn];
int siz[maxn],fa[maxn],son[maxn],pos[maxn],rk[maxn],tot;
void clear() {
	for(int i=1;i<=n;++i) {
		qwq[i].clear();
		w[i].clear();
		son[i]=wp[i]=fa[i]=0;
		for(int j=0;j<=1;++j) memset(Max[j][i],0,sizeof(Max[j][i]));
	}
	for(int i=1;i<=m;++i) vis[i]=0;
	tot=0;
}
void dfs1(int u) {
	siz[u]=1;
	for(int i=0;i<qwq[u].size();++i) {
		int v=qwq[u][i];
		if(v==fa[u]) continue;
		fa[v]=u;
		wp[v]=w[u][i];
		dep[v]=dep[u]+1;
		dfs1(v);
		siz[u]+=siz[v];
		if(!son[u]||siz[v]>siz[son[u]]) son[u]=v;
	}
}
void dfs2(int u,int tp) {
	pos[u]=++tot,rk[tot]=u;
	top[u]=tp;
	if(son[u]) dfs2(son[u],tp);
	for(int i=0;i<qwq[u].size();++i) {
		int v=qwq[u][i];
		if(v!=son[u]&&v!=fa[u]) dfs2(v,v);
	}
}
void solve() {
	for(int i=1;i<=n;++i) {
		Max[wp[rk[i]]&1][i][0]=wp[rk[i]];
		if(i==n) nxt[i][0]=0;
		else nxt[i][0]=i+1;
	}
	for(int j=1;j<=18;++j) {
		for(int i=1;i<=n;++i) {
			for(int k=0;k<=1;++k) 
				Max[k][i][j]=max(Max[k][i][j-1],Max[k][nxt[i][j-1]][j-1]);
			nxt[i][j]=nxt[nxt[i][j-1]][j-1];
		}
	}
}
int query(int l,int r,int p) {
	int x=logg[r-l+1];
	return max(Max[p][l][x],Max[p][r-(1<<x)+1][x]);
}
void update(int p) {
	int x=a[p].x,y=a[p].y;
	int res=0;
	while(top[x]!=top[y]) {
		if(dep[top[x]]<dep[top[y]]) swap(x,y);
		res=max(res,query(pos[top[x]],pos[x],!(a[p].z&1)));
		x=fa[top[x]];
	}
	if(dep[x]>dep[y]) swap(x,y);
	if(x!=y) res=max(res,query(pos[x]+1,pos[y],!(a[p].z&1)));
	if(res) tmp=min(tmp,ans+a[p].z-res);
}
int main() {
	ios::sync_with_stdio(0);
	cin.tie(0),cout.tie(0);
	cin>>T;
	Init();
	while(T--) {
		cin>>n>>m;
		for(int i=1;i<=m;++i) cin>>a[i].x>>a[i].y>>a[i].z;
		sort(a+1,a+1+m,comp);
		for(int i=1;i<=n;++i) f[i]=i;
		ans=0,tmp=1e18;
		int js=0,kp=0;
		for(int i=1;i<=m;++i) {
			int x=find(a[i].x),y=find(a[i].y);
			if(x!=y) {
				qwq[a[i].x].push_back(a[i].y);
				qwq[a[i].y].push_back(a[i].x);
				w[a[i].x].push_back(a[i].z);
				w[a[i].y].push_back(a[i].z);
				f[x]=y;
				ans+=a[i].z;
				vis[i]=1;
				if(a[i].z&1) js^=1;
				kp++;
			}
		}
		if(kp!=n-1) {
			clear();
            cout<<"-1 -1 \n";
			continue;
		}
		dfs1(1);
		dfs2(1,1);
		solve();
		for(int i=1;i<=m;++i) {
			if(vis[i]) continue;
			update(i);
		}
		if(js&1) swap(ans,tmp);
		if(ans==1e18) cout<<"-1 ";
		else cout<<ans<<' ';
		if(tmp==1e18) cout<<"-1\n";
		else cout<<tmp<<'\n';
		clear();
	}
	return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

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

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: 0
Accepted
time: 97ms
memory: 18760kb

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 1307926149
1189242112 1180186165
2248358640 2261370885
3776889482 3738936375
1093500444 1058677117
3433711014 3402127725
1201099898 1187873655
1395482806 1410162043
3456885934 3486092007
3943951826 3988876469
2479987500 2535532661
2909126794 293...

result:

ok 20000 numbers

Test #3:

score: 0
Accepted
time: 133ms
memory: 18656kb

input:

100
1806 5000
1 2 139994119
2 3 184924112
3 4 670813536
4 5 443325848
5 6 767909046
6 7 531742851
7 8 364385440
8 9 918195219
9 10 731896671
10 11 671688362
11 12 558665746
12 13 154497842
13 14 28636459
14 15 570343686
15 16 419626123
16 17 817852951
17 18 517701907
18 19 952451718
19 20 141747977
...

output:

380509244078 380509217939
236564714828 236564588423
317690341848 317690193297
416922743878 416923542879
411997066938 411996924725
231780454372 231780901543
156856996316 156856345151
239278757000 239278493321
288480848080 288481502909
347301406524 347301269265
362642903994 362643090967
158361335208 1...

result:

ok 200 numbers

Test #4:

score: 0
Accepted
time: 184ms
memory: 25544kb

input:

10
15547 50000
1 2 762013057
2 3 473514078
3 4 73078629
4 5 932961699
5 6 157436174
6 7 190061912
7 8 140204258
8 9 737720271
9 10 386190699
10 11 92718916
11 12 68384258
12 13 389445848
13 14 906761733
14 15 644882062
15 16 429774551
16 17 330771475
17 18 815808541
18 19 239714301
19 20 350847429
2...

output:

2833348523676 2833348592065
4133065384586 4133065395925
3395129351174 3395129357911
4109233311456 4109233300341
4201582590330 4201582656213
4055209304322 4055209286787
4274470524320 4274470529139
4221591172170 4221591328195
3155641613234 3155641574871
3656162030214 3656162010817

result:

ok 20 numbers

Test #5:

score: 0
Accepted
time: 279ms
memory: 86464kb

input:

1
200000 500000
1 2 485160054
2 3 698975729
3 4 100346974
4 5 820234671
5 6 389996728
6 7 914128102
7 8 439507064
8 9 938065130
9 10 353829140
2 11 391113348
7 12 685484428
8 13 492562017
7 14 269259412
4 15 133636977
7 16 189855044
16 17 393115842
9 18 196148136
13 19 272676317
1 20 778859832
12 21...

output:

46934564700640 46934564707403

result:

ok 2 number(s): "46934564700640 46934564707403"

Test #6:

score: 0
Accepted
time: 281ms
memory: 86508kb

input:

1
200000 500000
1 2 825868392
2 3 96775645
3 4 594837991
4 5 160657859
5 6 313806062
6 7 711860421
7 8 618363510
8 9 784016759
9 10 261473589
10 11 931365544
11 12 372625381
12 13 728196426
13 14 641630335
14 15 993361561
15 16 731849490
16 17 802998444
17 18 222098249
18 19 16513016
19 20 354524457...

output:

46801911175000 46801911171749

result:

ok 2 number(s): "46801911175000 46801911171749"

Test #7:

score: -100
Wrong Answer
time: 253ms
memory: 86496kb

input:

1
200000 500000
1 2 842585427
2 3 791026412
3 4 843625151
4 5 729586460
5 6 157528721
6 7 846617054
7 8 737344300
8 9 915918783
9 10 697382206
10 11 647361071
11 12 438594908
12 13 472804786
13 14 426537066
14 15 93901471
15 16 183637656
16 17 785203928
17 18 741855632
18 19 800547153
19 20 58723676...

output:

46131143829898 46131143843865

result:

wrong answer 2nd numbers differ - expected: '46131143836751', found: '46131143843865'