QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#630706#8941. Even or Odd Spanning TreeFHQY#WA 131ms9804kbC++202.3kb2024-10-11 20:05:192024-10-11 20:05:20

Judging History

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

  • [2024-10-11 20:05:20]
  • 评测
  • 测评结果:WA
  • 用时:131ms
  • 内存:9804kb
  • [2024-10-11 20:05:19]
  • 提交

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:fnd(b[x]);}
void merge(ll x,ll y){
	x=fnd(x),y=fnd(y);
	b[x]=y;
}
ll fa[maxn][19],dep[maxn];
ll mn[2][maxn][19];
void dfs(ll x){
	for(ll i=1;i<=18;i++){
		fa[x][i]=fa[fa[x][i-1]][i-1];
		if(!fa[x][i])break;
	}
	for(ll i=1;i<=18;i++){
		if(!fa[x][i])break;
		mn[0][x][i]=min(mn[0][fa[x][i-1]][i-1],mn[0][x][i-1]);
		mn[1][x][i]=min(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=18;i>=0;i--){
		if(dep[fa[x][i]]>=dep[y]){
			res=min(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=min(res,min(mn[ty][x][i],mn[ty][y][i]));
			x=fa[x][i],y=fa[y][i];
		}
	}
	res=min(res,min(mn[ty][x][0],mn[ty][y][0]));
	return res==inf?-inf: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=1;i<=n;i++){
		for(ll j=0;j<=18;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=inf;
	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[x].pb(mp(y,val)),e[y].pb(mp(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;
		ans=min(ans,sum+E[i].val-query(E[i].x,E[i].y,(E[i].val&1)^1));
	}
	if(sum%2==1)swap(sum,ans);
	if(sum==inf)sum=-1;
	if(ans==inf)ans=-1;
	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: 9788kb

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: 131ms
memory: 9804kb

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 -1125896684328541
1262790434 -1125898278998700
1263932600 -1125898258680234
-1125898475345011 1180186165
2248358640 -1125897177088222
-1125895797872707 3738936375
-1125898702948130 1058677117
-1125896313481520 3402127725
-1125898629918715 1187873655
1395482806 -1125898273460577
3456885934...

result:

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