QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#605124 | #8941. Even or Odd Spanning Tree | ucup-team4352# | WA | 281ms | 86508kb | C++23 | 2.9kb | 2024-10-02 15:38:20 | 2024-10-02 15:38:21 |
Judging History
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'