QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#666273 | #8941. Even or Odd Spanning Tree | lytqwq# | WA | 67ms | 27124kb | C++14 | 2.8kb | 2024-10-22 17:29:38 | 2024-10-22 17:30:00 |
Judging History
answer
#include<bits/stdc++.h>
#define pii pair<int,int>
#define mk make_pair
#define pb push_back
#define eb emplace_back
#define fi first
#define se second
#define fo(i,x,y) for(int i=x;i<=y;++i)
#define go(i,x,y) for(int i=x;i>=y;--i)
#define re return
#define co continue
#define sml(x,y) x=min(x,y)
#define big(x,y) x=max(x,y)
#define ll long long
using namespace std;
int read(){
int x=0,f=1;
int ch=getchar();
while(!isdigit(ch)){
if(ch=='-') f=-1;
ch=getchar();
}
while(isdigit(ch)){
x=x*10+(ch^48);
ch=getchar();
}
re x*f;
}
const int N=5e5+5;
const ll INF=1e18;
struct Edge{
int x,y,v;
bool operator<(const Edge &A){re v<A.v;}
}e[N];
int n,m,ban[N];
namespace Dsu{
int f[N];
void init(){fo(i,1,n) f[i]=i;}
int fin(int x){re f[x]==x?x:fin(f[x]);}
bool merge(int x,int y){
int fx=fin(x),fy=fin(y);
if(fx==fy) re 0;
f[fx]=fy;
re 1;
}
}
namespace Tree{
const int inf=1e9;
vector<pii> e[N];
void add(int x,int y,int v){
e[x].eb(y,v);
e[y].eb(x,v);
}
int lg[N],fa[N][21],dep[N];
int mx[N][21][2];
void init(){
fo(i,1,n) fa[i][0]=dep[i]=0,e[i].clear();
}
void dfs(int x){
dep[x]=dep[fa[x][0]]+1;
fo(i,1,lg[n]){
fa[x][i]=fa[fa[x][i-1]][i-1];
fo(o,0,1) mx[x][i][o]=max(mx[x][i-1][o],mx[fa[x][i-1]][i-1][o]);
}
for(auto i:e[x]) if(i.fi!=fa[x][0]){
fa[i.fi][0]=x;
mx[i.fi][0][i.se&1]=i.se;
mx[i.fi][0][(i.se&1)^1]=0;
dfs(i.fi);
}
}
int ask(int x,int y,int o){
if(dep[x]<dep[y]) swap(x,y);
int ret=0;
go(i,lg[n],0) if(dep[fa[x][i]]>=dep[y]) big(ret,mx[x][i][o]),x=fa[x][i];
if(x==y) re ret;
go(i,lg[n],0) if(fa[x][i]!=fa[y][i]){
big(ret,mx[x][i][o]),big(ret,mx[y][i][o]);
x=fa[x][i],y=fa[y][i];
}
big(ret,max(mx[x][0][o],mx[y][0][o]));
re ret;
}
}
void solve(){
cin>>n>>m;Dsu::init();Tree::init();
fo(i,1,n) ban[i]=0;
fo(i,1,m) e[i].x=read(),e[i].y=read(),e[i].v=read();
sort(e+1,e+1+m);
ll ans1=0,ans2=INF;
int cnt=0;
fo(i,1,m){
int x=e[i].x,y=e[i].y;
if(!Dsu::merge(x,y)) co;
Tree::add(x,y,e[i].v);
ans1+=e[i].v;
ban[i]=1;cnt++;
}
if(cnt<n-1){puts("-1 -1");re;}
Tree::dfs(1);
fo(i,1,m) if(!ban[i]){
int qwq=Tree::ask(e[i].x,e[i].y,(e[i].v&1)^1);
if(qwq<=0) co;
sml(ans2,ans1-qwq+e[i].v);
}
if(ans2<INF) assert((ans1&1)^(ans2&1));
if(ans1&1) swap(ans1,ans2);
cout<<(ans1<INF?ans1:-1)<<' '<<(ans2<INF?ans2:-1)<<'\n';
}
signed main(){
fo(i,2,N-1) Tree::lg[i]=Tree::lg[i>>1]+1;
int T=read();
while(T--) solve();
re 0;
}
/*
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
*/
详细
Test #1:
score: 100
Accepted
time: 0ms
memory: 27124kb
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: 67ms
memory: 25892kb
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 1207733704 1058677117 3433711014 3402127725 1201099898 1187873655 1395482806 1411327105 3456885934 3486092007 3943951826 3988876469 2479987500 2727710253 2909126794 293...
result:
wrong answer 13th numbers differ - expected: '1093500444', found: '1207733704'