QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#734605 | #2644. Cats or Dogs | Shumomo | Compile Error | / | / | C++14 | 3.4kb | 2024-11-11 13:13:18 | 2024-11-11 13:13:19 |
Judging History
answer
#include "catdog.h"
#include<bits/stdc++.h>
using namespace std;
int sz[100009],mx[100009],h[100009],ver[200009],nxt[200009],tot,ff[100009],tp[100009],dfn[100009];
struct node;
struct nd{
int x[2];
nd operator +(const node &aa)const{
nd cc;
cc.x[0]=x[0]+min(min(aa.x[2],aa.x[3])+1,min(aa.x[0],aa.x[1]));
cc.x[1]=x[1]+min(min(aa.x[2],aa.x[3]),min(aa.x[0],aa.x[1])+1);
return cc;
}
nd operator -(const node &aa)const{
nd cc;
cc.x[0]=x[0]-min(min(aa.x[2],aa.x[3])+1,min(aa.x[0],aa.x[1]));
cc.x[1]=x[1]-min(min(aa.x[2],aa.x[3]),min(aa.x[0],aa.x[1])+1);
return cc;
}
}g[100009];
struct node{
int x[4];
node operator +(const node &aa)const{
node cc;
cc.x[0]=min(min(x[0]+aa.x[2],x[1]+aa.x[0])+1,min(x[0]+aa.x[0],x[1]+aa.x[2]));
cc.x[1]=min(min(x[0]+aa.x[3],x[1]+aa.x[1])+1,min(x[0]+aa.x[1],x[1]+aa.x[3]));
cc.x[2]=min(min(x[2]+aa.x[2],x[3]+aa.x[0])+1,min(x[2]+aa.x[0],x[3]+aa.x[2]));
cc.x[3]=min(min(x[2]+aa.x[3],x[3]+aa.x[1])+1,min(x[2]+aa.x[1],x[3]+aa.x[3]));
return cc;
}
node operator +(const nd &aa)const{
node cc;
cc.x[1]=cc.x[2]=0x3f3f3f3f;
cc.x[0]=x[0]+min(aa.x[1]+1,aa.x[0]);
cc.x[3]=x[3]+min(aa.x[1],aa.x[0]+1);
return cc;
}
}f[100009],d[100009],val[400009];
void dfs1(int x,int fa){
for(int i=h[x];i;i=nxt[i]){
if(ver[i]!=fa){
dfs1(ver[i],x);
sz[x]+=sz[ver[i]];
if(sz[ver[i]]>sz[mx[x]])mx[x]=ver[i];
}
}
}
void dfs2(int x,int fa,int tt){
tp[x]=tt;
ed[tt]=x;
ff[x]=fa;
dfn[x]=++tot;
if(mx[x])dfs(mx[x],x,tt);
for(int i=h[x];i;i=nxt[i]){
if(ver[i]!=fa&&ver[i]!=mx[x]){
dfs2(ver[i],x,ver[i]);
}
}
}
void update(int rt,int l,int r,int ll,node rr){
if(l==r){
val[rt]=rr;
return;
}
int mid=(l+r)>>1;
if(ll<=mid)update(rt<<1,l,mid,ll,rr);
else update(rt<<1|1,mid+1,r,ll,rr);
val[rt]=val[rt<<1]+val[rt<<1|1];
}
node query(int rt,int l,int r,int ll,int rr){
if(l>rr||r<ll){
node rtn;
rtn.x[0]=rtn.x[1]=rtn.x[2]=rtn.x[3]=0;
return rtn;
}
if(l>=ll&&r<=rr)return val[rt];
int mid=(l+r)>>1;
return query(rt<<1,l,mid,ll,rr)+query(rt<<1|1,mid+1,r,ll,rr);
}
void initialize(int n,vector<int> A,vector<int> B) {
for(int i=0;i<n-1;i++){
tot++;
nxt[tot]=h[A[i]];
ver[tot]=B[i];
h[A[i]]=tot;
tot++;
nxt[tot]=h[B[i]];
ver[tot]=A[i];
h[B[i]]=tot;
}
dfs1(1,0);
tot=0;
dfs2(1,0,1);
}
int cat(int v){
f[v].x[0]=0;
f[v].x[1]=f[v].x[2]=f[v].x[3]=0x3f3f3f3f;
update(1,1,n,v,f[v]+g[v]);
while(v){
int u=tp[v];
int w=ed[v];
g[ff[u]]=g[ff[u]]-d[u];
d[u]=query(1,1,n,dfn[u],dfn[w]);
g[ff[u]]=g[ff[u]]+d[u];
update(1,1,n,ff[u],f[ff[u]]+g[ff[u]]);
}
return min(min(d[1].x[0],d[1].x[1]),min(d[1].x[2],d[1].x[3]));
}
int dog(int v) {
f[v].x[0]=f[v].x[1]=f[v].x[2]=0x3f3f3f3f;
f[v].x[3]=0;
update(1,1,n,v,f[v]+g[v]);
while(v){
int u=tp[v];
int w=ed[v];
g[ff[u]]=g[ff[u]]-d[u];
d[u]=query(1,1,n,dfn[u],dfn[w]);
g[ff[u]]=g[ff[u]]+d[u];
update(1,1,n,ff[u],f[ff[u]]+g[ff[u]]);
}
return min(min(d[1].x[0],d[1].x[1]),min(d[1].x[2],d[1].x[3]));
}
int neighbor(int v) {
f[v].x[0]=f[v].x[3]=0;
f[v].x[2]=f[v].x[3]=0x3f3f3f3f;
update(1,1,n,v,f[v]+g[v]);
while(v){
int u=tp[v];
int w=ed[v];
g[ff[u]]=g[ff[u]]-d[u];
d[u]=query(1,1,n,dfn[u],dfn[w]);
g[ff[u]]=g[ff[u]]+d[u];
update(1,1,n,ff[u],f[ff[u]]+g[ff[u]]);
}
return min(min(d[1].x[0],d[1].x[1]),min(d[1].x[2],d[1].x[3]));
}
詳細信息
answer.code: In member function ‘nd nd::operator+(const node&) const’: answer.code:10:38: error: invalid use of incomplete type ‘const struct node’ 10 | cc.x[0]=x[0]+min(min(aa.x[2],aa.x[3])+1,min(aa.x[0],aa.x[1])); | ^~ answer.code:5:8: note: forward declaration of ‘struct node’ 5 | struct node; | ^~~~ answer.code:10:46: error: invalid use of incomplete type ‘const struct node’ 10 | cc.x[0]=x[0]+min(min(aa.x[2],aa.x[3])+1,min(aa.x[0],aa.x[1])); | ^~ answer.code:5:8: note: forward declaration of ‘struct node’ 5 | struct node; | ^~~~ answer.code:10:61: error: invalid use of incomplete type ‘const struct node’ 10 | cc.x[0]=x[0]+min(min(aa.x[2],aa.x[3])+1,min(aa.x[0],aa.x[1])); | ^~ answer.code:5:8: note: forward declaration of ‘struct node’ 5 | struct node; | ^~~~ answer.code:10:69: error: invalid use of incomplete type ‘const struct node’ 10 | cc.x[0]=x[0]+min(min(aa.x[2],aa.x[3])+1,min(aa.x[0],aa.x[1])); | ^~ answer.code:5:8: note: forward declaration of ‘struct node’ 5 | struct node; | ^~~~ answer.code:11:38: error: invalid use of incomplete type ‘const struct node’ 11 | cc.x[1]=x[1]+min(min(aa.x[2],aa.x[3]),min(aa.x[0],aa.x[1])+1); | ^~ answer.code:5:8: note: forward declaration of ‘struct node’ 5 | struct node; | ^~~~ answer.code:11:46: error: invalid use of incomplete type ‘const struct node’ 11 | cc.x[1]=x[1]+min(min(aa.x[2],aa.x[3]),min(aa.x[0],aa.x[1])+1); | ^~ answer.code:5:8: note: forward declaration of ‘struct node’ 5 | struct node; | ^~~~ answer.code:11:59: error: invalid use of incomplete type ‘const struct node’ 11 | cc.x[1]=x[1]+min(min(aa.x[2],aa.x[3]),min(aa.x[0],aa.x[1])+1); | ^~ answer.code:5:8: note: forward declaration of ‘struct node’ 5 | struct node; | ^~~~ answer.code:11:67: error: invalid use of incomplete type ‘const struct node’ 11 | cc.x[1]=x[1]+min(min(aa.x[2],aa.x[3]),min(aa.x[0],aa.x[1])+1); | ^~ answer.code:5:8: note: forward declaration of ‘struct node’ 5 | struct node; | ^~~~ answer.code: In member function ‘nd nd::operator-(const node&) const’: answer.code:16:38: error: invalid use of incomplete type ‘const struct node’ 16 | cc.x[0]=x[0]-min(min(aa.x[2],aa.x[3])+1,min(aa.x[0],aa.x[1])); | ^~ answer.code:5:8: note: forward declaration of ‘struct node’ 5 | struct node; | ^~~~ answer.code:16:46: error: invalid use of incomplete type ‘const struct node’ 16 | cc.x[0]=x[0]-min(min(aa.x[2],aa.x[3])+1,min(aa.x[0],aa.x[1])); | ^~ answer.code:5:8: note: forward declaration of ‘struct node’ 5 | struct node; | ^~~~ answer.code:16:61: error: invalid use of incomplete type ‘const struct node’ 16 | cc.x[0]=x[0]-min(min(aa.x[2],aa.x[3])+1,min(aa.x[0],aa.x[1])); | ^~ answer.code:5:8: note: forward declaration of ‘struct node’ 5 | struct node; | ^~~~ answer.code:16:69: error: invalid use of incomplete type ‘const struct node’ 16 | cc.x[0]=x[0]-min(min(aa.x[2],aa.x[3])+1,min(aa.x[0],aa.x[1])); | ^~ answer.code:5:8: note: forward declaration of ‘struct node’ 5 | struct node; | ^~~~ answer.code:17:38: error: invalid use of incomplete type ‘const struct node’ 17 | cc.x[1]=x[1]-min(min(aa.x[2],aa.x[3]),min(aa.x[0],aa.x[1])+1); | ^~ answer.code:5:8: note: forward declaration of ‘struct node’ 5 | struct node; | ^~~~ answer.code:17:46: error: invalid use of incomplete type ‘const struct node’ 17 | cc.x[1]=x[1]-min(min(aa.x[2],aa.x[3]),min(aa.x[0],aa.x[1])+1); | ^~ answer.code:5:8: note: forward declaration of ‘struct node’ 5 | struct node; | ^~~~ answer.code:17:59: error: invalid use of incomplete type ‘const struct node’ 17 | cc.x[1]=x[1]-min(min(aa.x[2],aa.x[3]),min(aa.x[0],aa.x[1])+1); | ^~ answer.code:5:8: note: forward declaration of ‘struct...