QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#454918 | #7769. Axium Crisis | kkkgjyismine4 | 0 | 12ms | 12180kb | C++23 | 4.3kb | 2024-06-25 16:40:51 | 2024-06-25 16:40:51 |
Judging History
answer
#include<bits/stdc++.h>
#define pb push_back
#define pii pair<int,int>
#define fi first
#define se second
#define mp make_pair
using namespace std;
mt19937 rnd(time(0));
int dep[100500],son[100500][2],tot,rt,n;
pii ans[100500];
int id[100500],len[100500],Mask[100500],tt,fa[100500];
vector<pii>road[20];
vector<int>vec[100500];
vector<pii>Vec[100500];
map<pii,int>Mp;
int Rt;
const int inf=1e9;
int f[1<<17][20],d[1<<17][2];
struct Node{int pos,mask,lcp,Preval,lstd;}stk[15005000];
int tail;
void dfs(int u,int f,int p,int d,int m){
if(p>rt)vec[p].pb(m),Vec[p].pb(mp(Rt,u));
for(auto v:road[u]){
if(v.fi==f)continue;
int id1=Mp[mp(u,v.fi)];
if(u>v.fi)id1=Mp[mp(v.fi,u)];
if(v.se<2){
if(!son[p][v.se])son[p][v.se]=++tot,dep[tot]=dep[p]+1;
dfs(v.fi,u,son[p][v.se],d+1,(m|(1<<id1-1)));
}else{
if(d<2){
if(!son[p][0])son[p][0]=++tot,dep[tot]=dep[p]+1;
if(!son[p][1])son[p][1]=++tot,dep[tot]=dep[p]+1;
dfs(v.fi,u,son[p][0],d+1,(m|(1<<id1-1)));
dfs(v.fi,u,son[p][1],d+1,(m|(1<<id1-1)));
}else{
int o=rnd()%2;
if(!son[p][o])son[p][o]=++tot,dep[tot]=dep[p]+1;
dfs(v.fi,u,son[p][o],d+1,(m|(1<<id1-1)));
}
}
}
}
void Dfs(int p){
for(int i=0;i<vec[p].size();++i){
auto v=vec[p][i];id[++tt]=p,len[tt]=dep[p],Mask[tt]=v;
ans[tt]=Vec[p][i];
}
if(son[p][0])Dfs(son[p][0]);
if(son[p][1])Dfs(son[p][1]);
}
int LCP(int p,int q){
if(dep[p]>dep[q])swap(p,q);
while(dep[q]>dep[p])q=fa[q];
while(p!=q)p=fa[p],q=fa[q];
return dep[p];
}
int ht[20505];
int opr(int x){return son[fa[x]][1]==x;}
int Stk[20],Tail,pw[20];
int stk1[20],tail1;
void dfs1(int u,int f,int t){
if(tail1==-1)return;
stk1[++tail1]=u;
if(u==t){
for(int i=tail1-1;i>=1;--i)pw[Mp[mp(min(stk1[i],stk1[i+1]),max(stk1[i],stk1[i+1]))]]=Stk[i];
tail1=-1;
return;
}
for(auto v:road[u]){
if(tail1==-1)break;
if(v.fi==f)continue;
dfs1(v.fi,u,t);
}
if(tail1==-1)return;
--tail1;
}
void solve(){
scanf("%d",&n),Mp.clear();int tt1=0;
for(int i=1;i<=n;++i)road[i].clear();
for(int i=1;i<n;++i){
int u,v,w;scanf("%d%d%d",&u,&v,&w),pw[i]=w;++u,++v;
if(u>v)swap(u,v);Mp[mp(u,v)]=++tt1;
road[u].pb(mp(v,w)),road[v].pb(mp(u,w));
}
for(int i=1;i<=tot;++i)son[i][0]=son[i][1]=dep[i]=fa[i]=id[i]=0,vec[i].clear(),Vec[i].clear();
tot=rt=1,tt=0;
for(int i=1;i<=n;++i)Rt=i,dfs(i,-1,rt,0,0);
for(int i=1;i<=tot;++i){
if(son[i][0])fa[son[i][0]]=i;
if(son[i][1])fa[son[i][1]]=i;
}
Dfs(rt);
for(int i=0;i<(1<<n-1);++i)for(int j=0;j<=n-1;++j)f[i][j]=-inf,d[i][j]=0;
f[0][0]=0,tail=0;
int Ans=-inf,D=0;
for(int i=1;i<tt;++i)ht[i]=LCP(id[i],id[i+1]);
for(int i=1;i<=tt;++i){
int Val=len[i];if(i>1)Val=ht[i-1];
for(int j=0;j<(1<<n-1);++j){
int mx=-inf,from=-1;
for(int k=Val;k<n;++k){
if(f[j][k]>mx)mx=f[j][k],from=d[j][k];
stk[++tail]=Node{2*i-1,j,k,f[j][k],d[j][k]},f[j][k]=-inf;
}
f[j][Val]=mx,d[j][Val]=from;
}
for(int j=0;j<(1<<n-1);++j){
if(j&Mask[i])continue;
for(int k=0;k<n;++k){
int res=f[j][k]-k+len[i];
if(f[j|Mask[i]][len[i]]<res){
stk[++tail]=Node{2*i,(j|Mask[i]),len[i],f[j|Mask[i]][len[i]],d[j|Mask[i]][len[i]]};
f[j|Mask[i]][len[i]]=res,d[j|Mask[i]][len[i]]=k;
}
}
}
}
for(int i=0;i<n;++i)
if(Ans<f[(1<<n-1)-1][i])
Ans=f[(1<<n-1)-1][i],D=i;
printf("%d\n",Ans+1);
/* int Now=(1<<n-1)-1;
vector<int>Res;
for(int i=tt;i>=1;--i){
while(tail&&stk[tail].pos==2*i){
f[stk[tail].mask][stk[tail].lcp]=stk[tail].Preval;
d[stk[tail].mask][stk[tail].lcp]=stk[tail].lstd;
--tail;
}
Tail=0;
for(int j=id[i];j>rt;j=fa[j])Stk[++Tail]=opr(j);
reverse(Stk+1,Stk+Tail+1);
if((Now&Mask[i])==Mask[i]&&D==len[i]){
for(int k=0;k<n;++k)
if(f[Now^Mask[i]][k]-k+len[i]==Ans){
Now^=Mask[i],D=k,Ans=f[Now][D],Res.pb(i);
Rt=ans[i].fi,tail1=0,dfs1(ans[i].fi,-1,ans[i].se);
break;
}
}
while(tail&&stk[tail].pos==2*i-1){
f[stk[tail].mask][stk[tail].lcp]=stk[tail].Preval;
d[stk[tail].mask][stk[tail].lcp]=stk[tail].lstd;
--tail;
}
while(f[Now][D]<Ans)++D;
}
printf("%d\n",Res.size());
for(int i=1;i<n;++i)printf("%d ",pw[i]);
puts("");
for(auto v:Res)printf("%d %d\n",ans[v].fi-1,ans[v].se-1);*/
}
int main(){
puts("0");
int T,o;cin>>T>>o;
while(T--)solve();
return 0;
}
詳細信息
Subtask #1:
score: 0
Wrong Answer
Test #1:
score: 0
Wrong Answer
time: 4ms
memory: 12180kb
input:
1000 0 4 0 2 0 2 3 0 2 1 0 4 3 2 1 0 2 1 1 2 2 4 0 2 2 0 1 0 3 0 0 4 1 2 1 3 2 0 2 0 1 4 0 2 0 0 3 0 2 1 0 4 0 2 1 0 3 1 0 1 1 4 3 1 0 2 1 2 3 0 2 4 3 1 1 3 0 1 2 3 0 4 1 0 0 2 0 2 2 3 2 4 1 2 0 3 0 0 2 3 2 3 2 1 0 0 2 1 4 3 0 1 1 2 1 2 3 0 4 2 1 0 3 0 1 1 0 1 4 3 2 1 3 1 1 0 1 1 4 1 2 1 1 3 0 3 0 1...
output:
0 3 4 4 4 4 4 4 4 4 4 3 4 4 4 4 4 4 4 4 4 4 3 4 4 4 4 4 4 4 4 4 4 4 3 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 3 4 3 4 4 4 4 4 2 4 4 3 3 4 4 3 4 4 4 4 3 4 4 4 4 4 4 3 4 4 4 4 4 4 4 4 4 4 4 4 4 3 4 4 4 4 4 4 4 4 4 3 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 3 4 4 4 4 4 3 4 4 ...
result:
wrong answer Wrong Answer.
Subtask #2:
score: 0
Wrong Answer
Test #3:
score: 0
Wrong Answer
time: 12ms
memory: 8992kb
input:
3000 3 4 0 1 1 0 3 1 0 2 0 4 3 2 0 0 1 1 1 2 0 4 1 0 0 2 3 1 3 1 0 4 2 1 0 2 0 1 3 0 0 4 2 3 1 3 0 1 2 1 0 4 2 3 1 2 1 1 2 0 1 4 0 2 0 1 0 0 3 0 0 4 3 1 1 0 2 0 2 3 0 6 4 0 0 3 1 1 2 3 0 0 5 1 1 5 0 4 2 3 1 3 0 0 3 1 1 4 0 3 0 1 2 0 0 2 1 4 0 2 1 3 1 0 2 1 1 4 2 0 0 2 3 1 1 3 0 6 3 1 0 3 4 1 4 0 1 2...
output:
0 4 4 4 4 4 4 3 4 6 4 4 4 4 6 4 4 4 3 4 6 3 3 4 4 6 4 6 4 4 4 3 4 7 4 4 4 4 4 3 4 4 4 5 4 4 4 4 4 4 6 4 4 6 4 4 4 4 4 4 6 4 4 4 4 4 6 4 3 4 4 4 4 4 6 4 4 4 4 4 3 4 4 4 6 4 4 6 3 6 4 4 6 4 4 4 4 3 4 6 4 4 4 6 4 4 3 4 3 4 4 6 3 4 6 4 4 4 6 3 6 4 6 4 4 4 4 7 4 4 4 4 4 4 3 4 4 4 4 4 4 4 4 4 4 4 4 4 4 3 ...
result:
wrong answer Wrong Answer.
Subtask #3:
score: 0
Skipped
Dependency #1:
0%
Subtask #4:
score: 0
Skipped
Dependency #2:
0%
Subtask #5:
score: 0
Skipped
Dependency #3:
0%
Subtask #6:
score: 0
Skipped
Dependency #4:
0%
Subtask #7:
score: 0
Runtime Error
Test #13:
score: 0
Runtime Error
input:
3000 1 11 2 5 0 10 2 0 6 2 0 2 8 0 0 2 0 2 1 0 2 4 0 2 9 0 2 3 0 7 2 0 11 7 8 0 6 4 0 1 6 0 2 8 0 8 0 0 6 3 0 9 5 0 5 8 0 1 2 0 9 10 0 8 1 4 0 2 3 0 6 5 0 6 7 0 2 4 0 7 3 0 1 0 0 8 4 0 0 0 5 0 7 2 0 0 2 0 0 6 0 0 1 0 0 3 0 11 5 1 0 7 2 0 9 2 0 4 9 0 0 2 0 8 5 0 0 6 0 3 6 0 4 10 0 1 7 0 7 6 2 0 0 5 0...
output:
0
result:
Subtask #8:
score: 0
Runtime Error
Test #14:
score: 0
Runtime Error
input:
3000 2 8 4 7 2 4 3 2 3 2 2 4 5 2 1 4 2 6 4 2 0 1 2 8 1 5 2 0 7 2 3 2 2 3 1 2 5 7 2 4 0 2 6 4 2 8 1 3 2 5 3 2 7 6 2 2 6 2 0 7 2 4 6 2 0 5 2 8 5 7 2 2 6 2 1 6 2 4 5 2 4 0 2 0 1 2 7 3 2 11 2 7 2 0 9 2 8 9 2 10 7 2 6 9 2 9 3 2 4 10 2 7 5 2 7 9 2 1 9 2 8 2 6 2 1 5 2 4 1 2 1 3 2 6 1 2 0 1 2 6 7 2 14 2 6 2...
output:
0
result:
Subtask #9:
score: 0
Skipped
Dependency #6:
0%
Subtask #10:
score: 0
Skipped
Dependency #5:
0%