HDU 2874 Connections between cities(LCA离线算法实现)

http://acm.hdu.edu.cn/showproblem.php?pid=2874

题意:

求两个城市之间的距离。

 

思路:

LCA题,注意原图可能不连通。

如果不了解离线算法的话,可以看我之前博客写的解释http://www.cnblogs.com/zyb993963526/p/7295894.html

  1 #include<iostream>
  2 #include<algorithm>
  3 #include<cstring>
  4 #include<cstdio>
  5 #include<sstream>
  6 #include<vector>
  7 #include<stack>
  8 #include<queue>
  9 #include<cmath>
 10 #include<map>
 11 #include<set>
 12 using namespace std;
 13 typedef long long ll;
 14 typedef pair<int,int> pll;
 15 const int INF = 0x3f3f3f3f;
 16 const int maxn=10000+5;
 17 const int M=1000010;
 18 
 19 int n, m, c;
 20 int etot,qtot;
 21 int ehead[maxn];
 22 int qhead[maxn];
 23 int mark[maxn];
 24 int dis[maxn];
 25 int vis[maxn];
 26 
 27 int ans[M];
 28 int p[maxn];
 29 
 30 struct node
 31 {
 32     int v,w;
 33     int next;
 34 }e[2*maxn];
 35 
 36 struct Node
 37 {
 38     int v;
 39     int index;
 40     int next;
 41 }query[2*M];
 42 
 43 void addEdge(int u, int v, int w)
 44 {
 45     e[etot].v=v;
 46     e[etot].w=w;
 47     e[etot].next=ehead[u];
 48     ehead[u]=etot++;
 49 }
 50 
 51 void addQuery(int u, int v, int i)
 52 {
 53     query[qtot].v=v;
 54     query[qtot].index=i;
 55     query[qtot].next=qhead[u];
 56     qhead[u]=qtot++;
 57 }
 58 
 59 int Find(int x)
 60 {
 61     return p[x]==x?x:p[x]=Find(p[x]);
 62 }
 63 
 64 void LCA(int u)
 65 {
 66     vis[u]=1;
 67     for(int i=qhead[u];i!=-1;i=query[i].next)
 68     {
 69         int v=query[i].v;
 70         if(vis[v] && !mark[Find(v)])  //mark数组是为了针对非连通图的情况
 71             ans[query[i].index]=dis[u]+dis[v]-2*dis[Find(v)];
 72     }
 73 
 74     for(int i=ehead[u];i!=-1;i=e[i].next)
 75     {
 76         int v=e[i].v;
 77         if(!vis[v])
 78         {
 79             dis[v]=dis[u]+e[i].w;
 80             LCA(v);
 81             p[v]=u;
 82         }
 83     }
 84 }
 85 
 86 int main()
 87 {
 88     //freopen("in.txt","r",stdin);
 89     while(~scanf("%d%d%d",&n,&m,&c))
 90     {
 91         etot=qtot=0;
 92         memset(qhead,-1,sizeof(qhead));
 93         memset(ehead,-1,sizeof(ehead));
 94         for(int i=1;i<=n;i++)  p[i]=i;
 95 
 96         while(m--)
 97         {
 98             int u,v,w;
 99             scanf("%d%d%d",&u,&v,&w);
100             addEdge(u,v,w);
101             addEdge(v,u,w);
102         }
103 
104         for(int i=1;i<=c;i++)
105         {
106             int u,v;
107             scanf("%d%d",&u,&v);
108             addQuery(u,v,i);
109             addQuery(v,u,i);
110         }
111 
112         memset(ans,-1,sizeof(ans));
113         memset(vis,0,sizeof(vis));
114         memset(mark,0,sizeof(mark));
115         for(int i=1;i<=n;i++)
116         {
117             if(!vis[i])
118             {
119                 dis[i]=0;
120                 LCA(i);
121                 mark[i]=1;
122             }
123         }
124         for(int i=1;i<=c;i++)
125         {
126             if(ans[i]==-1)   puts("Not connected");
127             else printf("%d\n",ans[i]);
128         }
129     }
130     return 0;
131 }

 

转载于:https://www.cnblogs.com/zyb993963526/p/7295969.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/572143.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SpringMVC中的异步请求-跨域访问

发送异步请求&#xff1a; <%page pageEncoding"UTF-8" language"java" contentType"text/html;UTF-8" %><a href"javascript:void(0);" id"testAjax">访问springmvc后台controller</a><br/> <…

P1080 国王游戏

题目描述 恰逢 H 国国庆&#xff0c;国王邀请 n 位大臣来玩一个有奖游戏。首先&#xff0c;他让每个大臣在左、右手上面分别写下一个整数&#xff0c;国王自己也在左、右手上各写一个整数。然后&#xff0c;让这 n 位大臣排成一排&#xff0c;国王站在队伍的最前面。排好队后&a…

SpringMVC配置静态资源加载, 中文乱码处理,注解驱动

常规配置&#xff08;Controller加载控制&#xff09; SpringMVC的处理器对应的bean必须按照规范格式开发&#xff0c;未避免加入无效的bean可通过bean加载过滤器进行包含设定或排除设定&#xff0c;表现层bean标注通常设定为Controller业务层与数据层bean加载由Spring控制&…

Android App性能測试

一、内存 1、查看单个应用App最大内存限制 Command&#xff1a;adb shell “getprop|grep heapgrowthlimit” C:\Users\hujiachun>adb shell "getprop|grep heapgrowthlimit" [dalvik.vm.heapgrowthlimit]: [128m] 128M是单个APP最大内存限制&#xff0c;假设Dalv…

SpringMVC-HandlerInterceptor拦截器的使用与参数详解

拦截器概念&#xff1a; 拦截器&#xff08; Interceptor&#xff09;是一种动态拦截方法调用的机制&#xff0c;请求处理过程解析核心原理&#xff1a; AOP思想拦截器链&#xff1a;多个拦截器按照一定的顺序&#xff0c;对原始被调用功能进行增强 作用&#xff1a; 在指定的…

使用FindBugs-IDEA插件找到代码中潜在的问题

另一篇使用文档&#xff0c;参照&#xff1a;https://www.cnblogs.com/huaxingtianxia/p/6703315.html 我们通常都会在APP上线之后,发现各种错误,尤其是空指针异常,这些错误对于用户体验来说是非常不好的,但其实大部分的问题,我们都能够提前发现. 在编写代码的过程中,可能不会时…

SpringMVC异常处理 自定义异常

异常处理器 实现HandlerExceptionResolver接口&#xff08;异常处理器&#xff09; Component // 配上注解Spring看到实现了这个接口就知道是异常处理器了 public class ExceptionResolver implements HandlerExceptionResolver {public ModelAndView resolveException(HttpSe…

霍炬:再谈百度:KPI、无人机,以及一个必须给父母看的案例

霍炬&#xff1a;再谈百度&#xff1a;KPI、无人机&#xff0c;以及一个必须给父母看的案例 作者&#xff1a;霍炬。 原文链接&#xff1a;http://www.donews.com/idonews/article/8147.shtm没想到我之前的一篇关于百度的文章引起了这么大的反馈。非常多朋友称赞我写的好&…

使用SpringMVC模拟文件上传与下载案例

文件上传下载 SpringMVC封装了Tomcat的上传文件功能 MultipartResolver接口 MultipartResolver接口定义了文件上传过程中的相关操作&#xff0c;并对通用性操作进行了封装MultipartResolver接口底层实现类CommonsMultipartResovlerCommonsMultipartResovler并未自主实现文件上…

JSR表单校验框架

表单校验的重要性&#xff1a; 表单校验保障了数据有效性、安全性 不适用表单检验数据可以随意输入&#xff0c;导致错误的结果。后端表单校验的重要性&#xff0c;比如输入框采集成绩&#xff0c;如果前端做了检验&#xff0c;但是用户比较牛逼&#xff0c;他在地址栏上直接加…

使用Phantom omni力反馈设备控制机器人

传统的工业机器人普遍采用电机 、齿轮减速器 、关节轴三者直接连接的传动机构&#xff0c;这种机构要求电机与减速器安装在机械臂关节附近&#xff0c;其缺点是对于多关节机械臂&#xff0c;下一级关节的电机与减速器等驱动装置成为上一级关节的额外负载 。这一额外负载带来的负…

Go_配置系统环境MacOS(M1)

在MacOS下和JDK一样&#xff0c;配不配环境其实MacOS都是可以检测的到的&#xff0c;安装好以后直接输入go version是一样可以的&#xff0c;因为都是使用开发工具的&#xff0c;在开发工具里配置的话是样的&#xff0c;如果有习惯的话就配置一下吧 下载安装及配置环境&#xf…

Android setBackgroundResource和setBackgroundDrawable和用法

两个方法的效果是一样&#xff0c;只是区别于效率&#xff01;playBtn.setBackgroundResource(R.drawable.pause_selecor); 从上面可以看出来是从资源文件中获取drawable中的pause_selecor对象&#xff0c;如果是经常要用到的drawable对象&#xff0c;就可以让它成为一个成员变…

Go_变量使用详解

变量 变量的本质是计算机分配的一块内存&#xff0c;用于存放数据&#xff0c;变量是在程序运行过程中&#xff0c;其值可以发生改变的数据&#xff0c;变量属于临时存储&#xff0c;当程序运行结束&#xff0c;存放该数据的内存就会释放&#xff0c;该变量就会随着内存的释放…

硬币找零问题,动态规划基础,百度面试题

问题描述&#xff1a;给出几种面值的硬币&#xff0c;要求用这几种硬币找零出所给零钱数&#xff0c;用的硬币数要最少。 过去我们用过贪心法解决此类问题&#xff0c;包括本人在百度面试时&#xff0c;也是用的贪心法&#xff08;面试官对这个解答不满意&#xff09;&#xff…

Go_数据类型

数据类型&#xff1a; 计算机存储设备最小信息单位是位&#xff08;bit&#xff09;&#xff0c;最小的存储单元是字节&#xff08;byte&#xff09;&#xff0c;占用字节的不同&#xff0c;所表示能存储的数据长度不同。数据类型用来说明数据的数据的结构&#xff0c;便于后面…

HashMap之扰动函数和低位掩码

我们都知道&#xff0c;hashMap在实现的时候&#xff0c;为了寻找在数组上的位置&#xff0c;主要做了两件事 int hash hash(key); int i indexFor(key, table.length); 这个时候得到i才是数组上的位置。 这两个方法详解如下 JDK8对扰动函数的修改&#xff0c;只进行了一次移…

Go_运算符及优先级

运算符&#xff1a; 很久以前&#xff0c;流传程序算法数据这样的说法。算法是什么&#xff1f;通俗点说就是解决问题的过程。小到加法指令&#xff0c;大到成千上万台服务器组成的分布式计算集群。抛去抽象概念和宏观架构&#xff0c;最终都由最基础的机器指令过程去处理不同层…

mvn 修改所有子项目pom版本

mvn versions:set -DgenerateBackupPomsfalse -DnewVersion1.3.0 转载于:https://www.cnblogs.com/sidesky/p/7344713.html

Go_流程、跳转控制语详解

流程控制语句分类&#xff1a; 流程控制语句可以控制代码的执行顺序和条件 顺序结构&#xff1a;普通的代码&#xff0c;由上而下依次执行分支结构(if, switch)循环结构(for) if语句&#xff1a; 条件表达式值必须是bool类型&#xff0c;不可省略括号&#xff0c;且左大括号…