标签:有一个 ref src 连接方式 输入 efi next def limit
Time Limit: 10 Sec Memory Limit: 64 MB
Submit: 507 Solved: 246
[Submit][Status][Discuss]
距离最远的两个点之中,一定有一个是在当前政党中深度最深的,枚举另一个点,更新政党范围
mdzz我居然用点编号和深度去比较!!
1 #include <cstdio> 2 3 const int N(2e5+5); 4 int a[N],p[N],deps[N],ans[N]; 5 int head[N],sumedge; 6 struct Edge 7 { 8 int v,next; 9 Edge(int v=0,int next=0):v(v),next(next){} 10 }edge[N<<1]; 11 inline void ins(int u,int v) 12 { 13 edge[++sumedge]=Edge(v,head[u]); 14 head[u]=sumedge; 15 edge[++sumedge]=Edge(u,head[v]); 16 head[v]=sumedge; 17 } 18 19 #define max(a,b) (a>b?a:b) 20 #define swap(a,b) {int tmp=a;a=b,b=tmp;} 21 int dad[N],dep[N],size[N],son[N],top[N]; 22 void DFS(int u) 23 { 24 size[u]=1; 25 dep[u]=dep[dad[u]]+1; 26 for(int v,i=head[u];i;i=edge[i].next) 27 { 28 v=edge[i].v; 29 if(dad[u]==v) continue; 30 dad[v]=u; DFS(v); size[u]+=size[v]; 31 if(size[son[u]]<size[v]) son[u]=v; 32 } 33 } 34 void DFS_(int u,int Top) 35 { 36 top[u]=Top; 37 if(son[u]) DFS_(son[u],Top); 38 for(int v,i=head[u];i;i=edge[i].next) 39 { 40 v=edge[i].v; 41 if(dad[u]!=v&&son[u]!=v) DFS_(v,v); 42 } 43 } 44 int LCA(int x,int y) 45 { 46 for(;top[x]!=top[y];y=dad[top[y]]) 47 if(dep[top[x]]>dep[top[y]]) swap(x,y); 48 return dep[x]<dep[y]?x:y; 49 } 50 51 inline void read(int &x) 52 { 53 x=0; register char ch=getchar(); 54 for(;ch>‘9‘||ch<‘0‘;) ch=getchar(); 55 for(;ch>=‘0‘&&ch<=‘9‘;ch=getchar()) x=x*10+ch-‘0‘; 56 } 57 inline void write(int x) 58 { 59 if(x/10) write(x/10); 60 putchar(x%10+‘0‘); 61 } 62 int AC() 63 { 64 // freopen("cowpol.in","r",stdin); 65 // freopen("cowpol.out","w",stdout); 66 67 int n,k,rt; read(n),read(k); 68 for(int i=1;i<=n;i++) 69 { 70 read(a[i]),read(p[i]); 71 if(!p[i]) rt=i; 72 else ins(p[i],i); 73 } 74 DFS(rt); DFS_(rt,rt); 75 for(int i=1;i<=n;i++) 76 if(dep[i]>dep[deps[a[i]]]) deps[a[i]]=i; 77 for(int lca,i=1;i<=n;i++) 78 { 79 lca=LCA(i,deps[a[i]]); 80 ans[a[i]]=max(ans[a[i]],dep[i]+dep[deps[a[i]]]-dep[lca]*2); 81 } 82 for(int i=1;i<=k;i++) 83 write(ans[i]),puts(""); 84 return 0; 85 } 86 87 int I_want_AC=AC(); 88 int main(){;}
COGS——T 803. [USACO Hol10] 政党 || 1776: [Usaco2010 Hol]cowpol 奶牛政坛
标签:有一个 ref src 连接方式 输入 efi next def limit
原文地址:http://www.cnblogs.com/Shy-key/p/7434595.html