前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【HDU 2874】Connections between cities(LCA)

【HDU 2874】Connections between cities(LCA)

作者头像
饶文津
发布2020-06-02 15:52:51
3960
发布2020-06-02 15:52:51
举报
文章被收录于专栏:饶文津的专栏饶文津的专栏

dfs找出所有节点所在树及到树根的距离及深度及父亲。

i和j在一棵树上,则最短路为dis[i]+dis[j]-dis[LCA(i,j)]*2。

代码语言:javascript
复制
#include <cstring>
#include <cstdio>
#define N 10005
#define add(u,v,w) e[++cnt]=(edge){v,head[u],w};head[u]=cnt
using namespace std;
struct edge{
    int to,next,w;
}e[N<<1];
int head[N],cnt,f[N],dis[N],deep[N],tr[N],t;
int fa(int i,int j){
    while(i!=j)
        if(deep[i]>deep[j])
            i=f[i];
        else 
            j=f[j];
    return i;
}
void dfs(int x,int p){
    tr[x]=t;
    deep[x]=deep[p]+1;
    f[x]=p;
    for(int i=head[x];i;i=e[i].next){
        int v=e[i].to;
        if(v==p)continue;
        dis[v]=dis[x]+e[i].w;
        dfs(v,x);
    }
}
int main(){
    int n,m,c,u,v,w;
    while(~scanf("%d%d%d",&n,&m,&c)){
        memset(head,0,sizeof head);
        memset(f,0,sizeof f);
        cnt=t=0;
        for(int i=1;i<=m;i++){
            scanf("%d%d%d",&u,&v,&w);
            add(u,v,w);
            add(v,u,w);
        }
        for(int i=1;i<=n;i++)
            if(f[i]==0){
                t++;
                dfs(i,0);
            }
        for(int i=1;i<=c;i++){
            scanf("%d%d",&u,&v);
            if(tr[u]!=tr[v])
                puts("Not connected");
            else
                printf("%d\n",dis[u]+dis[v]-dis[fa(u,v)]*2);
        }
    }
}
  
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016-08-07 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档