QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#631024 | #8941. Even or Odd Spanning Tree | FHQY# | WA | 125ms | 15952kb | C++17 | 2.3kb | 2024-10-11 21:28:29 | 2024-10-11 21:28:31 |
Judging History
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][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]=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=18;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<=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=-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: 15888kb
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: 125ms
memory: 15952kb
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 1411327105 3456885934 3486092007 3943951826 3949300341 2479987500 2535532661 2909126794 302...
result:
wrong answer 20th numbers differ - expected: '1410162043', found: '1411327105'