QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#631048#8941. Even or Odd Spanning TreeFHQY#WA 113ms15896kbC++172.3kb2024-10-11 21:36:372024-10-11 21:36:39

Judging History

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

  • [2024-10-11 21:36:39]
  • 评测
  • 测评结果:WA
  • 用时:113ms
  • 内存:15896kb
  • [2024-10-11 21:36:37]
  • 提交

answer

#include<bits/stdc++.h>
#define ll long long
using namespace std;
const ll maxn=2e5+5,maxm=5e5+5,inf=-1ll<<50;
ll n,m;
struct edge1{
	ll x,y,val;
	friend bool operator < (const edge1 &x,const edge1 &y){
		return x.val==y.val?x.x<y.x:x.val<y.val;
	}
}E[maxm];
ll b[maxn];
vector<pair<ll,ll> >e[maxn];
#define mp make_pair
#define fi first
#define se second
#define pb push_back
ll fnd(ll x){return b[x]==x?x:b[x]=fnd(b[x]);}
void merge(ll x,ll y){
	x=fnd(x),y=fnd(y);
	b[x]=y;
}
ll fa[maxn][18],dep[maxn];
ll mn[2][maxn][18];
void dfs(ll x){
	for(ll i=1;i<=17;i++){
		fa[x][i]=fa[fa[x][i-1]][i-1];
	}
	for(ll i=1;i<=17;i++){
		mn[0][x][i]=max(mn[0][fa[x][i-1]][i-1],mn[0][x][i-1]);
		mn[1][x][i]=max(mn[1][fa[x][i-1]][i-1],mn[1][x][i-1]);
	}
	for(auto it:e[x]){
		ll v=it.fi,val=it.se;
		if(v==fa[x][0])continue;
		fa[v][0]=x;
		mn[val&1][v][0]=val;
		dep[v]=dep[x]+1;
		dfs(v);
	}
}
ll query(ll x,ll y,ll ty){
	if(dep[x]<dep[y])swap(x,y);
	ll res=inf;
	for(ll i=17;i>=0;i--){
		if(dep[fa[x][i]]>=dep[y]){
			res=max(res,mn[ty][x][i]);
			x=fa[x][i];
		}
	}
	if(x==y)return res;
	for(ll i=18;i>=0;i--){
		if(fa[x][i]!=fa[y][i]){
			res=max(res,max(mn[ty][x][i],mn[ty][y][i]));
			x=fa[x][i],y=fa[y][i];
		}
	}
	res=max(res,max(mn[ty][x][0],mn[ty][y][0]));
	return res;
}
bool vis[maxm];
void solve(){
	cin>>n>>m;
	for(ll i=1;i<=n;i++)b[i]=i,e[i].clear();
	for(ll i=0;i<=n;i++){
		for(ll j=0;j<=17;j++){
			mn[0][i][j]=mn[1][i][j]=inf;
		}
	}
	for(ll i=1;i<=m;i++){
		cin>>E[i].x>>E[i].y>>E[i].val;
		vis[i]=0;
	}
	sort(E+1,E+1+m);
	ll sum=0,ans=-1;
	for(ll i=1;i<=m;i++){
		ll x=E[i].x,y=E[i].y,val=E[i].val;
		x=fnd(x),y=fnd(y);
		if(x!=y)merge(x,y),sum+=val,e[E[i].x].pb(mp(E[i].y,val)),e[E[i].y].pb(mp(E[i].x,val)),vis[i]=1;
	}
	for(ll i=1;i<=n;i++){
		if(fnd(i)!=fnd(1)){
			cout<<"-1 -1"<<endl;
			return ;
		}
	}
	dep[1]=1;
	dfs(1);
	for(ll i=1;i<=m;i++){
		if(vis[i])continue;
		ll res=query(E[i].x,E[i].y,(E[i].val&1)^1);
		if(res==-1)continue;
		if(ans==-1)ans=sum+E[i].val-res;
		else ans=min(ans,sum+E[i].val-res);
	}
	if(sum%2==1)swap(sum,ans);
	cout<<sum<<" "<<ans<<endl;
}
ll T=1;
signed main(){
	ios::sync_with_stdio(false);
	cin.tie(0);
	cout.tie(0);
	cin>>T;
	while(T--){
		solve();
	}
	return 0;
}

详细

Test #1:

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

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: 113ms
memory: 15896kb

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 3056189431
1262790434 1263237173
1263932600 1307926149
1189242112 1180186165
2248358640 2122689779
3776889482 3738936375
978767168 1058677117
3433711014 3402127725
1085898538 1187873655
1395482806 1411327105
3456885934 3459440551
3943951826 3644735087
2479987500 2535532661
2909126794 2663...

result:

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