https://nanti.jisuanke.com/t/31462

要求在一个矩形中任意选两个点都有唯一的通路,所以不会建多余的墙。

要求满足上述情况下,建墙的费用最小。理解题意后容易想到首先假设全部墙都建起来,然后拆掉费用最大的边使图成为一棵树,就是求一颗最大生成树

求出最大生成树后,求任意两点的距离,直接用lca就可以

思路

  1. #include<bits/stdc++.h>
  2. #define M 300005
  3. #define pb push_back
  4. using namespace std;
  5. struct E{
  6. int u,v,w;
  7. E(int w,int u,int v):w(w),u(u),v(v){}
  8. bool operator<(const E& rhp)const{
  9. return w>rhp.w;
  10. }
  11. };
  12. vector<E>e;
  13. int fa[M];int fin(int u){return fa[u]==u?u:fa[u]=fin(fa[u]);}
  14. int pr[M][30],d[M],n,m,i,j,a,b,u,v,x,y,x1,x2,Y1,y2,LCA,q;
  15. char s[10];
  16. vector<int>g[M];
  17. void dfs(int u,int fa){
  18. pr[u][0]=fa;
  19. for(int i=1;i<=19;i++)pr[u][i]=pr[pr[u][i-1]][i-1];
  20. for(int i=0;i<g[u].size();i++){
  21. int v=g[u][i];if(v==fa)continue;
  22. d[v]=d[u]+1;
  23. dfs(v,u);
  24. }
  25. }
  26. int lca(int u,int v){
  27. if(d[u]<d[v])swap(u,v);
  28. int dep=d[u]-d[v];
  29. for(int i=19;i>=0;i--){
  30. if(dep&(1<<i)){
  31. dep^=(1<<i);
  32. u=pr[u][i];
  33. }
  34. }
  35. if(u==v)return u;
  36. for(int i=19;i>=0;i--){
  37. if(pr[u][i]!=pr[v][i]){
  38. u=pr[u][i];v=pr[v][i];
  39. }
  40. }
  41. return pr[u][0];
  42. }
  43. int main(){
  44. scanf("%d%d",&n,&m);
  45. for(i=1;i<=n*m+m;i++)fa[i]=i;
  46. for(i=1;i<=n;i++){
  47. for(j=1;j<=m;j++){
  48. scanf("%s %d %s %d",s,&a,s,&b);
  49. if(i<n){
  50. e.pb(E(a,i*m+j,(i+1)*m+j));
  51. }
  52. if(j<m){
  53. e.pb(E(b,i*m+j,i*m+j+1));
  54. }
  55. }
  56. }
  57. sort(e.begin(),e.end());
  58. for(i=0;i<e.size();i++){
  59. u=e[i].u;v=e[i].v;
  60. x=fin(u);y=fin(v);
  61. if(x!=y){
  62. fa[x]=y;
  63. g[u].pb(v);g[v].pb(u);
  64. }
  65. }
  66. dfs(1*m+1,0);
  67. scanf("%d",&q);
  68. while(q--){
  69. scanf("%d%d%d%d",&x1,&Y1,&x2,&y2);
  70. u=x1*m+Y1;v=x2*m+y2;
  71. LCA=lca(u,v);
  72. printf("%d\n",d[u]+d[v]-2*d[LCA]);
  73. }
  74. }

ACM-ICPC 2018 徐州赛区网络预赛 J Maze Designer(最大生成树,倍增lca)的更多相关文章

  1. ACM-ICPC 2018 徐州赛区网络预赛 J. Maze Designer (最大生成树+LCA求节点距离)

    ACM-ICPC 2018 徐州赛区网络预赛 J. Maze Designer J. Maze Designer After the long vacation, the maze designer ...

  2. ACM-ICPC 2018 徐州赛区网络预赛 J. Maze Designer 最大生成树 lca

    大概就是要每两个点 只能有一条路径,并且约束,最短的边用来砌墙,那么反之的意思就是最大的边用来穿过 故最大生成树 生成以后 再用lca计算树上两点间的距离 (当然防止生成树是一条链,可以用树的重心作为 ...

  3. ACM-ICPC 2018 徐州赛区网络预赛 J Maze Designer(最大生成树+LCA)

    https://nanti.jisuanke.com/t/31462 题意 一个N*M的矩形,每个格点到其邻近点的边有其权值,需要构建出一个迷宫,使得构建迷宫的边权之和最小,之后Q次查询,每次给出两点 ...

  4. ACM-ICPC 2018 徐州赛区网络预赛 J. Maze Designer

    传送门:https://nanti.jisuanke.com/t/31462 本题是一个树上的问题:结点间路径问题. 给定一个有N×M个结点的网格,并给出结点间建立墙(即拆除边)的代价.花费最小的代价 ...

  5. ACM-ICPC 2018 徐州赛区网络预赛 G. Trace (思维,贪心)

    ACM-ICPC 2018 徐州赛区网络预赛 G. Trace (思维,贪心) Trace 问答问题反馈 只看题面 35.78% 1000ms 262144K There's a beach in t ...

  6. 计蒜客 1460.Ryuji doesn't want to study-树状数组 or 线段树 (ACM-ICPC 2018 徐州赛区网络预赛 H)

    H.Ryuji doesn't want to study 27.34% 1000ms 262144K   Ryuji is not a good student, and he doesn't wa ...

  7. ACM-ICPC 2018 徐州赛区网络预赛 B(dp || 博弈(未完成)

    传送门 题面: In a world where ordinary people cannot reach, a boy named "Koutarou" and a girl n ...

  8. ACM-ICPC 2018 徐州赛区网络预赛 B. BE, GE or NE

    In a world where ordinary people cannot reach, a boy named "Koutarou" and a girl named &qu ...

  9. ACM-ICPC 2018 徐州赛区网络预赛 F. Features Track

    262144K   Morgana is learning computer vision, and he likes cats, too. One day he wants to find the ...

随机推荐

  1. 【Linux 进程】exec族函数详解

    exec族的组成: 在Linux中,并不存在一个exec()的函数形式,exec指的是一组函数,一共有6个,分别是: #include <unistd.h> extern char **e ...

  2. django的model操作整理

    单表操作 增加数据 auther_obj = {"auther_name":"崔皓然","auther_age":1} models.aut ...

  3. eclipse及tomcat设置编码

    新装的eclipse新导入项目会乱码,解决办法: 右击项目选properties,找到resources选择utf-8 改后乱码解决 乱码解决后可能还会有红叉,project clean即可 一劳永逸 ...

  4. java 基础之--nio 网络编程

    在传统的Java 网络编程中,对于客户端的每次连接,对于服务器来说,都要创建一个新的线程与客户端进行通讯,这种频繁的线程的创建,对于服务器来说,是一种巨大的损耗,在Java 1.4 引入Java ni ...

  5. xml转Map,对象,Map转xml,inputs tram 转xml 字符串的工具类方法

    众所周知,大家在微信开发工程中,由于微信开发文档中,对于消息的接收发送都是基础xml数据的(太坑了),所以我们需要对XML进行解析转换: 1.我们先引入所需要的依赖 dom4j (解析xml的),xs ...

  6. 本地DNS解析

    企业搭配本地域名,进行解析 2018年07月23日 09:31:46 阅读数:2 搭建dns服务器,可以进行域名解析,这样方便企业项目本地测试. 可以实现,输入域名访问本地服务器 一.安装软件 1.下 ...

  7. ES6 Decorator 修饰器

    目的:  修改类的一种方法,修饰器是一个函数 编译: 安装 babel-plugin-transform-decortators-legacy .babelrd      plugins: [&quo ...

  8. webpack浅析---入口篇

    webpack有四个核心概念: 入口(entry) 输出(output) loader 插件(plugins) webpack-merge将环境.构建目标.运行时合并 入口: 入口起点是指webpac ...

  9. YII2中查询生成器Query()的使用

    YII2中的yii\db\Query给我们提供了非常丰富的方法,方便我们构建复杂的SQL语句. Query()与createCommand最大区别在于,后者直接使用我们写好的SQL语句,前者通过参数和 ...

  10. (转)system.badimageformatexception 未能加载文件或程序集

    “/xxxxx”应用程序中的服务器错误. ------------------------------------------------------------------------------- ...