ACM-ICPC 2018 徐州赛区网络预赛 J Maze Designer(最大生成树,倍增lca)

时间:2021-08-03 06:15:05

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

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

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

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

思路

#include<bits/stdc++.h>
#define M 300005
#define pb push_back
using namespace std;
struct E{
int u,v,w;
E(int w,int u,int v):w(w),u(u),v(v){}
bool operator<(const E& rhp)const{
return w>rhp.w;
}
};
vector<E>e;
int fa[M];int fin(int u){return fa[u]==u?u:fa[u]=fin(fa[u]);}
int pr[M][30],d[M],n,m,i,j,a,b,u,v,x,y,x1,x2,Y1,y2,LCA,q;
char s[10]; vector<int>g[M]; void dfs(int u,int fa){
pr[u][0]=fa;
for(int i=1;i<=19;i++)pr[u][i]=pr[pr[u][i-1]][i-1];
for(int i=0;i<g[u].size();i++){
int v=g[u][i];if(v==fa)continue;
d[v]=d[u]+1;
dfs(v,u);
}
} int lca(int u,int v){
if(d[u]<d[v])swap(u,v);
int dep=d[u]-d[v];
for(int i=19;i>=0;i--){
if(dep&(1<<i)){
dep^=(1<<i);
u=pr[u][i];
}
}
if(u==v)return u;
for(int i=19;i>=0;i--){
if(pr[u][i]!=pr[v][i]){
u=pr[u][i];v=pr[v][i];
}
}
return pr[u][0];
}
int main(){
scanf("%d%d",&n,&m);
for(i=1;i<=n*m+m;i++)fa[i]=i;
for(i=1;i<=n;i++){
for(j=1;j<=m;j++){
scanf("%s %d %s %d",s,&a,s,&b);
if(i<n){
e.pb(E(a,i*m+j,(i+1)*m+j));
}
if(j<m){
e.pb(E(b,i*m+j,i*m+j+1));
}
}
}
sort(e.begin(),e.end());
for(i=0;i<e.size();i++){
u=e[i].u;v=e[i].v;
x=fin(u);y=fin(v);
if(x!=y){
fa[x]=y;
g[u].pb(v);g[v].pb(u);
}
}
dfs(1*m+1,0);
scanf("%d",&q);
while(q--){
scanf("%d%d%d%d",&x1,&Y1,&x2,&y2);
u=x1*m+Y1;v=x2*m+y2;
LCA=lca(u,v);
printf("%d\n",d[u]+d[v]-2*d[LCA]);
}
}

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

  1. ACM-ICPC 2018 徐州赛区网络预赛 J&period; Maze Designer &lpar;最大生成树&plus;LCA求节点距离&rpar;

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

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

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

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

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

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

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

  5. ACM-ICPC 2018 徐州赛区网络预赛 G&period; Trace &lpar;思维,贪心&rpar;

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

  6. 计蒜客 1460&period;Ryuji doesn&&num;39&semi;t want to study-树状数组 or 线段树 &lpar;ACM-ICPC 2018 徐州赛区网络预赛 H&rpar;

    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 &vert;&vert; 博弈(未完成)

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

  8. ACM-ICPC 2018 徐州赛区网络预赛 B&period; BE&comma; 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&period; Features Track

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

随机推荐

  1. HDU 1024Max Sum Plus Plus&lpar;最大m字段和&rpar;

    /* 动态转移方程:dp[i][j]=max(dp[i-1]+a[i], max(dp[t][j-1])+a[i]) (j-1<=t<i) 表示的是前i个数j个字段和的最大值是多少! */ ...

  2. 35&period; Search Insert Position

    题目: Given a sorted array and a target value, return the index if the target is found. If not, return ...

  3. 新手篇丨Python任意网段Web端口信息探测工具

    你学习Python的目的是什么?是想写爬虫爬取数据(数据.图片等内容),还是想自写自动化的小工具,又或是作为一个新手小白单纯的欣赏这门语言呢? 今天i春秋分享的是一篇关于多线程工具的文章,工具使用效率 ...

  4. &lbrack;jzoj&rsqb;4216&period;【NOIP2015模拟9&period;12】平方和

    Link https://jzoj.net/senior/#main/show/4216 Description 给出一个N个整数构成的序列,有M次操作,每次操作有一下三种: ①Insert Y X, ...

  5. JavaScript面向对象编程指南&lpar;四&rpar; 对象

    第4章 对象 4.1 从数组到对象 对象的组成:变量名.{}.用逗号分割的属性.用冒号分割的键/值对. var f={ name:'alen', // 可以在属性名上加引号 age:12 }; 对象文 ...

  6. Django框架----Object Relational Mapping&lpar;ORM&rpar;

    Django中的ORM Django项目使用MySQL数据库 1. 在Django项目的settings.py文件中,配置数据库连接信息: DATABASES = { "default&qu ...

  7. 容器viewController添加或者删除子viewController

    假设有一个viewControllerA,我们想在viewControllerA中添加viewControllerB,需要执行以下方法: [viewControllerA addChildViewCo ...

  8. sourcetree 跳过注册

    https://www.cnblogs.com/lucio110/p/8192792.html

  9. C&plus;&plus;面向对象高级开发课程(第三周)

    一,类与类之间的关系:继承(Inheritance).复合(Composition).委托(Delegation). 二,复合:表示 is-a ,该设计思想可以参照C语言的 struct . 1. 例 ...

  10. Web前端工程师常去的15个技术网站

    1.CSDN 网址:https://www.csdn.net/ 简介: CSDN (Chinese Software Developer Network) 创立于1999年,是中国最大的IT社区和服务 ...