ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Sgu149 Computer Network

2019-05-03 09:39:17  阅读:211  来源: 互联网

标签:md Network cm color rgb Computer 0px border Sgu149


Sgu149 Computer Network

题目描述

给你一棵N(N<=10000)个节点的树,求每个点到其他点的最大距离。


不难想到一个节点到其他点的最大距离为:max(以它为根的子树的最大深度,根节点到它的距离+根节点的另外所有的子树(没有这个点的子树)的最大深度)。

我们不妨分两次求解出上面的两个答案的元素。显然第一个很好求,我们直接看第二个。

设整棵树的最大深度为dep1,次大深度为dep2,根节点为r。如果当前节点u不在最大深度的那棵子树上,那么它的第二个答案元素的最大距离就为:dis(r,u)+dep1,其中dis(i,j)为i到j的距离,即i的深度减j的深度的绝对值。否则,最大距离就为:dis(r,u)+dep2。

次大距离可以在求第一个元素的时候算一下。

     
xxxxxxxxxx
   
#include<iostream>
#include<cstring>
#include<cstdio>
#define maxn 10001
using namespace std;

inline int read(){
    register int x(0),f(1); register char c(getchar());
    while(c<'0'||'9'<c){ if(c=='-') f=-1; c=getchar(); }
    while('0'<=c&&c<='9') x=(x<<1)+(x<<3)+(c^48),c=getchar();
    return x*f;
}

struct edge{
    int to,next;
    edge(){}
    edge(const int &_to,const int &_next){
        to=_to,next=_next;
    }
}e[maxn<<1];
int head[maxn],k;
inline void add(const int &u,const int &v){
    e[k]=edge(v,head[u]);
    head[u]=k++;
}

int dp[maxn][2],n;
void dfs1(int u,int pre){
    for(register int i=head[u];~i;i=e[i].next){
        int v=e[i].to;
        if(v==pre) continue;
        dfs1(v,u);
        int tmp=dp[v][0]+1;
        if(tmp>dp[u][0]) swap(tmp,dp[u][0]);
   
        if(tmp>dp[u][1]) swap(tmp,dp[u][1]);//次大距离
    }
}
void dfs2(int u,int pre){
    for(register int i=head[u];~i;i=e[i].next){
        int v=e[i].to;
        if(v==pre) continue;
        int tmp;
        if(dp[u][0]==dp[v][0]+1) tmp=dp[u][1]+1;
        else tmp=dp[u][0]+1;
        if(tmp>dp[v][0]) swap(tmp,dp[v][0]);
        if(tmp>dp[v][1]) swap(tmp,dp[v][1]);
        dfs2(v,u);
    }
}

int main(){
    memset(head,-1,sizeof head);
    n=read();
    for(register int i=1;i<n;i++){
        int u=read(),v=read();
        add(u,v),add(v,u);
    }
    dfs1(1,0);//以它为根的子树的最大深度
    dfs2(1,0);//根节点到它的距离+根节点的另外所有的子树(没有这个点的子树)的最大深度
    for(register int i=1;i<=n;i++) printf("%d\n",dp[i][0]);
    return 0;
}
   

 

<style></style>

标签:md,Network,cm,color,rgb,Computer,0px,border,Sgu149
来源: https://www.cnblogs.com/akura/p/10804365.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有